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ADVANCED DIGITAL CORP. is proud to introduce its HDC-1001 
hard disk controller board. The HDC-1001 is a single board 
controller with ECC (error correction) and CRC all on one board. 
It follows the IEEE-696 standards and will fit it to any S-100 
Motherboard. 
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1. INTRODUCTION 



is-li. iscgcal Besscifit ice 

The HDC-1001 is an S-100 bus Winchester Controller board with error 
correction (ECO capabilities. It is designed to interface up to four 
Winchester disk drives. There are two versions of the board, the HDC-1001- 
5/8. The HDC-1001-B can operate 8" drives. The HDC-1001-5 is used with 
most 5-1/4" drives. 

The drive signals are based upon the floppy look-alike interface available 
on the Shugart Associates' SO 1000, the Seagate Technology ST506, and other 
compatible drives. fill necessary buffers and receivers/drivers are 
included on the board to allow direct connection to the drive. Four 20 pin 
radial connectors are provided for data. Either a 34 pin (5-1/4" drive) or 
a 50 pin (8" drive) connector is provided for drive control. 

fill data to be written to or read from the disk, status information, and 
macro commands are transferred via the S-100 bus. fin on board sector 
buffer allows data transfers to the host computer independent of the actual 
data transfer rate of the drive. 



*NOTE: In this manual the S-100 interface is called the "Host." 
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* S-10O IEEE 696 

* Single BV Supply 

* Built-in Data Separator 

* Built-in Write Precompensat i on logic 

* Data rates up to 5 Mb its/sec 

* Control for up to 4 drives 

* Control for up to Q R/W heads 

* 1824 cylinder addressing range 

* £56 sector addressing range 

* CRC generation/verification 

* Automatic formatting 

* 1S8, 256, or 512 bytes per sector (User selectable) 

* Unlimited sector interleave capability 

* Multiple sector reads and writes 

* Overlap seek capability 

* Implied seek on all commands 

* Automatic retries on all errors 

* Automatic restore and re-seek on seek error 

* Error correction on data field errors 

* Diagnostic reads and writes for checking error correction 

* Power Consumption +5V © 2. 5 amps 
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Encoding method: 

Cylinders per Head: 

Sectors per Track: 

Heads: 

Drive Selects: 

Step rate: 

Data Transfer Rate: 

Write Precomp Time: 
CRC Polynomial : 
ECC Po 1 y nom i a 1 : 

Reciprocal ECC Polynomial: 

Miscorrect ion Probability: 

Non-detection Probability: 

Correct i on Span : 

Sectoring: 

Host Interface: 

Drive Capability: 

Drive Cable Length: 

Power Req u i r ement s : 

Ambient Operating Temperature: 

Relative Humidity: 

MTBF: 

MTTR: 



MFM 

Up to 1024 

Up to £56 (512 byte sec) 

8 

4 

35 uS to 7. 5 mS <0. 5 mS increments) 

4.34 Mbits/sec (SA1000) 

5.000 Mbits/sec (ST506) 

12 nanoseconds 

X**16+X**12+X**5+l 

X**32+X**28+X**26+X**19+X**17+X**10+ 

X**6+X**2+l 

X**32+X**30+X**26+X**22+X**15+X**13+ 

X**6+X**4+l 

256 byte sector - <8. E-6 

512 byte sector - <1.5 E-5 

-2.3 E-10 

5 bits 

Soft 

8 Bit bi-directional Bus 

10 LS Loads 

10 ft. (3 M) max. 

+8V, 3. 0fl Max (2. 5A typ. ) 

C to 50 C (32 F to 122 F) 

20* to 80* 

10,000 POH 

30 minutes 
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lils. §i!2Blifigd System Hock Diagram. 
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2. INTERFACE CONNECTORS 

X.- 

The HDC-1001 has six on board connectors. These connectors consist of a 
two drive control connector, and four high speed data connectors. 

The drive control cable is daisy-chained to each of the four drives. 

The drive data connectors carry differential signals and are radially 
connected. Up to four drives can be accommodated by the HDC-1001. 

§«-§&. BEivg Control Signals 

The Drive Control connector <J5 and J6> is a (relatively) low speed bus 
that is daisy chain connected to each of up to four drives in the system. 
To properly terminate each TTL level output signal from the HDC-1001, the 
last drive in the daisy chain should have a 220/330 ohm line termination 
resistor pack installed. fill other drives should have no termination. 
Drive Control Signals are as follows: 



2. 2. 1 . RWC- 



2.2.2. Write Gate- 



When the Reduce Write Current line is activated with 
Write Gate, a lower write current is used to compensate 
for greater bit packing density on the inner cylinders. 
The RWC~ line is activated when the cylinder number is 
greater than or equal to four times the contents of the 
Write Pnecomp Register. 



This output signal allows data to be written to the 

disk. 



2.2.3. Seek Complete- 

In forms the HDC-1001 that the head of the selected 
drive has reached the desired cylinder and has 
stabilized. Seek Complete is not checker) after a SEEK 
command, thus allowing overlapped seeks. 

2.2.4. Track 000- 

Indicates that the R/W heads are positioned on the 
outermost cylinder. This line is sampled immediately 
before each step is issued. 

2.2.5. Write Fault- 

Informs t+ie MDC-1001 that some fault has occurred on 
the sleeted drive. The HDC-1001 will not execute commands 



2. 2. 6. HS0-HS2- 



Head Select lines are used by the HDC-1001 to select a 

specific R/W head on the selected drive. 
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£.2.7. Sector- 



For hard sectored drives, this line is 
the sector boundries during formatting, 
line is not used unless special PROMs 
handle hard sectored drives. 



used to indicate 

Note that this 

stre installed to 



2.2.8. 



Index- 



Is used to indicate the index point for synchronization 
during formatting and as a time out mechanism for 
retries. This signal should pulse once each rotation 
of the disk. 



S. 2. 9. Ready- 



Informs the HDC-1801 that the desired drive is selected 
and that its motor is up to speed. The HDC-1001 will 
not execute commands unless this line is true. 



2.2.10. Step- 



This line is pulsed once for each cylinder to be 
stepped. The direction of the step will be determined 
by the Direction In- line. The step pulse period is 
determined by the internal stepping rate register 
during implied seek operations or explicitly during 
Seek and Restore commands. During auto restore, the 
step pulse period is determined by the Seek Complete- 
time from the drive. 



2.2.11. Direction In- 

Determines the direction of motion of the R/W head when 

the step line is pulsed. ft high on this line defines 

the direction as out and a low defines direction as in. 



2.2.12. DS1-DS4- 



These four Drive Select lines &re used to select one of 
four possible drives. 
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2.2.13. Control Driver/ Receiver 

The control lines have the following electrical specifications: 

True= 0.0 V to 0. 4 V at I in » 40 ma. (max.) 
False= 2.5 V to 5. ES V at I in » -0 ma. (open) 



♦sv 
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2.2.1 4. 50 Pin Drive Control Connector 



This Drive Control Connector <J5) is a 58 pin vertical header on tenth-inch 
centers that mates with Burndy #FRS50BS. The cable used should be flat 
ribbon cable or twisted pair with a length of less than 10 feet. The cable 
pin-outs bvb as follows: 



-+ 
I 



I 
+- 



Signal Ground I Signal Pin I I/O I Signal Name 



1 

3 

5 

7 

9 

11 

13 

15 

17 

19 

£1 

23 

25 

27 

29 

31 

33 

35 

37 

39 

41 

43 

45 

47 

49 



2 

4 

& 

8 

10 

12 

14 

16 

18 

20 

22 

24 

26 

28 

30 

32 

34 

36 

38 

40 

42 

44 

46 

48 

50 



1 1 


RWC- 


1 


Head Select 2- 




NC 


1 I 


Seek Complete- 




NC 




NC 


1 


Head Select 0- 


1 I 


Sector- 


1 


Head Select 1- 


1 I 


Index- 


1 I 


Ready- 




NC 


1 


Drive Select 1 


1 


Drive Select 2 


I 


Drive Select 3 


1 


Drive Select 4 


1 


Direction In- 


1 


1 Step- 




NC 


1 


1 Write Gate- 


1 I 


TR000- 


I I 


Write Fault- 




1 NC 




1 NC 




NC 



-+ 



+ 
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2. 2. IS. 34 Pin Drive Control Connector 



This Drive Control connector <J6) is a 34 pin vertical header on tenth- inch 
centers that mates with Burndy #FRS34BS. The cable used should be flat 
ribbon cable or twisted pair with a length of less than 10 feet. The cable 
pin-outs are as follows: 



-+ 

I 

-+ 



I Signal Ground 

+ 

1 

3 

5 

7 

9 

11 

13 

15 

17 

19 

21 

23 

25 

27 

29 

31 

33 



1 Signal Pin 1 I\0 


Signal Name 


1 2 





RWC- 


1 4 
1 6 
1 a 

1 10 

1 12 
1 14 




I 
I 
I 



Head Select 2- 
Write Gate- 
Seek Com p let e- 
TR000- 

Write Fault- 
Head Select 0- 


1 16 
1 18 
1 20 
1 22 
1 24 
1 26 


I 

I 
I 




Sector- 

Head Select 1- 

Index- 

Ready- 

Step- 

Drive Select 1 


1 28 
1 30 
1 32 







Drive Select 2 
Drive Select 3 
Drive Select 4 


1 34 





Direction In- 



-+ 



+ 



§a.2a- Drive Data Signals 



The Drive Data Connectors carry the high speed differential MFM data 
between the drive and the HDC-1001. Due to the loading characteristics of 
these differential lines, each of the drives have their own data connector. 
Drive Data Signals are as follows: 

2.3.1. Drive Selected- 

This signal is not used on the HDC-1001. 

2.3.2. Timing Clock* 

One half of the differential Timing Clock signal. This 
line contains a square wave signal equal to 1/84 the 
frequency of the write clock crystal. 



2.3.3. Timing Clock- 



This is the complimentary version of Timing Clock+. 



2.3.4. MFM Write Data+- 

Dif ferent ial MFM data from the controller to the disk. 
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2.3.5. MFM Read Data-t— 

Differential MFM data from the disk to the controller. 

£.3.6. Drive Data Connectors 

Four Data connectors (Jl-4) are provided for clock signals and data between 
the HDC-1001 and each drive. fill lines associated with the transfer of 
data between the drive and the HDC-1001 system are differential in nature 
and may not be multiplexed. The Data connectors are £0 pin vertical 
headers on tenth-inch centers that mate with Burndy #FRS£0BS. The cable 
used should be flat ribbon cable or twisted pair with a length of less than 
10 feet. The cable pin-outs are as follows: 



-+ 

I 

-+ 



i Signal Ground I 

+ +- 



4 
6 

a 



Signal Pin I I/O 



11 
IS 



IS 
16 



19 
20 



I 
-+- 



Signal Name 



1 1 


I 1 


Drive Selected 


3 1 




NC 




5 


I 


Writ 


e Protect - 


7 




NC 




9 1 





Timing Clocks- 


10 





Timing Clock- 






GND 








GND 




13 





MFM 


Write Data+ 


14 





MFM 

GND 

1 GND 


Write Data- 


17 


I 


MFM 


Read Data+ 


18 


I 


1 MFM 
1 GND 
1 GND 


Read Data- 



-H 



H 1— 



£.3.7. Differential Data Driver/ Receiver 



HIGH 
TRUE 



AMD 26LS31 
or 751 10A 



NOTE: ANY RS 422 
DRIVER/RECEIVER PAIR 
WILL INTERFACE 




HIGH 
TRUE 



= AMD 26LS32 



FLAT RIBBON OR TWISTED PAIR 
MAX 10 FT. 



10 
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3. INTERFACE TIMING 
2a.it BCiYl CSDtCSl IiffliQB 



-+ 
I 



I SYMBOL 

+ 

tWG 
tDS 

tsw 

tSP 

tss 
tsc 



CHARACTERISTIC 



MIN MAX 



UNITS 



Write gate pulse width 1 sector £ rotation 

Direction to step delay £50 

Step pulse width 5<typical» 

Programmed Step pulse period 0.01 7.5 

Step to Seek Complete false 9 

Last Step to seek Complete 1£Q 



nS 

uS 

uS 

uS 

Index 

t imes 



Notes: 

1. Write gate pulse width will vary depending on the sector size and 
the rotation rate of the disk. 

2. Step pulse period will be equal to seek complete time during au, 
restore. 



- DR SEL, HO SEL ^X 



xz 



- rwc W/////17A VALID 



- WRITE GATE 



W W//////////////////////, 



*«— tWG — < 

I 



tDS— , 

-D.RECTON 7777777m7m 



- STEP 



tsw 



tss— < ,— 

i I 



-SEEK COMPLETE 



tSP 



-J 



-ih 



i r* 



h 



tsc 



T_ 



ii 
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3-.2j. Driygt data jtiasinfl 

+ + 

I SYMBOL CHARACTERISTIC MIN MAX UNITS I 

+ + 

I tTC Timing clock period WCLK/16 (typical) I 

I tWD Write data pulse width 60 120 nS I 

I tRD Read data pulse width £5 nS I 

+ + 



+ TIMING CLOCK 



-TIMING CLOCK 




nrLTLn-TLTLr 



+ MFM WRITE DATA 
- MFM WRITE DATA 



J 



two 



i ■ 



T_n 



+ MFM READ DATA_ 
- MFM READ DATA 



1 



i i 

i ■ 



tRD 



r 



12 



4. TASK FILE 



&1.1&. Iaiis Eils iasics 

The HDC-1001 performs all disk functions through a set of registers called 
the Task File. These register &re loaded with parameters such as Sector 
Number, Cylinder Number, etc., prior to issuing a command. Individual 
registers Brs selected via 00-2. The following registers are available: . 



4.S.S&. Bsgistec Sees*. 



-+ 

i 
-+ 



I CS- I AS I AM M I RE- 



I WE- 



1 1 


1 X 


1 X 


1 X 


Deselected 1 


1 


I 


1 


i 


Data Register 1 


1 


1 


1 


1 1 


Error Register 1 


1 


1 


i 1 


1 


Sector Count 1 


1 


1 


1 1 


1 1 


Sector Number 1 


1 


1 1 


I 


1 


Cylinder Low 1 


1 


1 1 


1 


1 1 


Cylinder High 1 


1 


1 1 


I 1 


1 


Size/Drive/Head 1 


1 


1 1 


1 1 


1 1 


Status Register 1 



Deselected 
Data Register 
Write Precomp 
Sector Count 
Sector Number 
Cylinder Low 
Cylinder High 
Size/Drive/Head 
Command Register 



iiSs. Register Ss£ADAt ions 

4.3.1. Command Register 

All commands are loaded into this register after the 
task registers have been set. Writing to this register 
will cause the INTRQ Line to be reset. The Command 
register is a write-only register. 

4.3.2. Status Register 

After execution of a command, the Status register is 
internally loaded with status information pertaining to 
the command executed. The host must read this register 
to determine successful execution of the command. The 
Status register is a read-only register; it cannot be 
written to by the host. If the busy bit is set, no 
other bits in this register are valid. Accessing this 
register will cause the INTRQ line to be reset. 



4.3.3. SDH Register 



This register contains the ECC mode, sector Size, Drive 
select, and Head select bits. The SDH register is a 
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read/write register organized as follows! 



I 4 



17 16! 

+ 

I E I Sec I Drive I 
I I Size i Select I 



I 2 







I 

h 

Head I 
Select I 



E=0 CRC in data field 
E=l ECC in data field 



1 Bit 
1 6 


Bit 
5 




Sector Size 


1 
1 


1 
1 


Bit 
4 


Bit 
3 


Dr 


ive Selected 1 

1 


f 
i 

1 1 




1 
1 




25S Bytes 
512 Bytes 
128 Bytes 




1 
1 
1 


1 
1 
1 
1 





1 
1 




1 



1 


Dr 
Dr 
Dr 
Dr 


ive Sel 1 1 
ive Sel 2 1 
ive Sel 3 1 
ive Sel 4 ■ 1 






+• 


Bit 

2 


Bit 
1 


Bit 






Heac 


I Selected 


















1 






Head 
Head 1 














1 


1 
1 





1 







Head 2 
Head 3 
Head 4 












1 
1 
1 



1 

1 


1 


1 






Head 5 
Head 6 
Head 7 







4.3.4. Cylinder Number 

These two read/write registers form the cylinder number 
where the head is to be positioned on a Seek, Read, 
Write, or Format command. Internally, a separate set 
of cylinder register values at^e maintained for each 
drive. The two least significant bits of the Cylinder 
High register form the most significant bits of the 
cylinder number as illustrated below: 



Register 
Cyl inder 



bits: 
bits: 



Cylinder High 
7T6T5T4T3 I 2 I 1 I t 
I I I I I 19181 



l7l6l5l4l3liTll0l 
I7I6I5I4I3I2I1 101 



4. 3. 5. Sector number 

This register is loaded with the desired sector number 
prior to a Read or Write command. The Sector Number 
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register is a read/write register and may be read or 
written to by the host. 

4.3.6. Sector Count 

This read/write register is loaded with the number of 
sectors to be processed. On Read or Write multiple 
commands, the number of sectors to be transferred is 
loaded into this register. During a Format command, 
this register is loaded with the number of sectors to 
be formatted. During the course of a command, the 
Sector Count register is decremented towards zero and 
should be re- loaded for each command. 

4.3.7. Error Register 

This register contains specific fault information pei — 
taining to the last command executed. This register is 
valid only if the Error bit in the Status register is 
set. The Error register is read only. 

4.3.8. Write Precomp 

The Write Precornpensat ion register holds the cylinder 
number where the RWC line will be asserted and Write 
Precornpensat ion logic is to be turned on. This write- 
only register is loaded with the cylinder number 
divided-by-4 to achieve a range of 10S4 cylinders. For 
example, if write precornpensat ion is desired for 
cylinder 1£S <8<3 Hex) and higher, this register must be 
loaded with 3£ <£0 Hex). The Write Precornpensat ion 
delay is fixed at 1£ nanoseconds from nominal. On 
drives that require separate write precornpensat ion and 
reduce write current cylinders, set the Write Precomp 
register to the cylinder where write current reduction 
is desired. 

4.3.9. Data Register 

This register is the user's window to the on-board full 
sector buffer. It contains the next byte of data to be 
written to or read from the internal sector buffer. 
The Data register is accessed once for each byte in the 
sector. When the DRQ (Data ReQuest ) line is asserted, 
the sector buffer contains data in a read command, or 
is awaiting data to be written during a write command 
into the Data register. If the HDC-1001 is interfaced 
using programmed I/O, data transfers to this register 
can be implemented using block moves. This register may 
not be read from or written to except in the conte*' of 
a valid command. 
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fts.lt. Status Registers 

There are two registers in the HDC-1801 that are used to monitor the execution 
of commands. They are the Status register and the Error register. Each bit 
of these registers is used to define a particular type of status or error 
condit ion. 



1 Bit 1 


St at us Reg i st er 


1 


Error Register 


1 


I 7 


Busy 




Bad Block Detect 




1 & 


Ready 




Uncorrectable 




1 5 


Write Fault 




CRC Error - ID Field 




1 4 


Seek Complete 




ID Not Found 




1 3 


Data Request 




— 




1 o 

1 1— 


1 Corrected 




Aborted Command 




1 1 


_ 




TR000 Error 




1 


Error 




DAM Not Found 





£•.5.. §tatug Reflisjj.gr Sits 
4.5.1. Error 



When set, indicates that a bit is set in the Error 
register. It provides an efficient means of checking 
for an error condition by the host. This bit is reset 
on receipt of a new command. 



4.5.2. Correct ed 



Indicates that there was a read error condition either 
in the data field or the ECC check bits themselves, and 
that the controller was able to correct the condition. 



4.5.3. Data Request 



Functions almost identically to the hardware DRQ " ine. 
When set, it indicates that the sector buffer is ready 
to accept data or contains data to be read out by the 
host. The Data Request bit is reset when the sector 
buffer has been fully read from or written to. 
Normally, the host need not consult this bit to 
determine if a byte should be transferred. 



4.5.4. Seek Complete 

Indicates the condition of the Seek Complete line on 

the selected drive. 



•fi *~i m w • 



Write Fault 



Indicates the condition of the Write Fault line on 
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selected drive. The HDC-1001 will not execute any 
command if this bit is set. 



4. 5. 6. Ready 



Indicates the condition of the Ready line of the 
selected drive. The HDC-1001 will not execute any 
commands unless this bit is set. 



4.. 5. 7. Busy 

After issuing a command, this bit will be set, 
indicating that the HDC-1001 is busy executing a 
command. No other bits or registers are valid when 
this bit is set. 

4. 6. 1 . DAM Not Found 

Will be set during a Read Sector command if, after 
successfully identifying the ID field, the Data Address 
mark was not detected within IS bytes of ID field. 

4.6.2. TR000 Error 

Will be set during a Restore command if, after issuing 
1024 stepping pulses, the Track 000 line was not 
asserted by the drive. 

4. 6. 3. Aborted Command 

Indicates that a valid command has been received that 
cannot be executed, based on status information from 
the drive. For example, if a write sector command has 
been issued while the Write Fault line is set, the 
Aborted Command bit will be set. Interrogation of the 
Status and/or Error registers by the host can be 
performed to determine the cause of failure. 

4. 6. 4. ID Not Found 

When set, this bit indicates that an ID field 
containing a specified cylinder, head, sector number or 
sector size was not found. 

4.6.5. CRC Error ID 

Indicates that a CRC error was encountered in an ID 

field. 
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4. £.6. Uncorrectable 

Indicates that an error was detected while reading the 
data field or ECC check bits and the error was so 
severe that the controller was not able to correct the 
condition. 

4.6.7. Bad Block Detect 

Indicates that a Bad Block Mark has been detected in 
the specified ID field. If the command issued was a 
write sector command, no writing will be performed. If 
generated from a read sector command, the data field 
will not be read. Note that bad block will not be 
detected if the flaw is in the ID field unless multiple 
ID fields were written. 
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selected drive. The HDC-1001 will not execute any 
command if this bit is set. 



4. 5. 6. Ready 



Indicates the condition of the Ready line of the 
selected drive. The HDC-1001 will not execute any 
commands unless this bit is set. 



4. 5. 7. Busy 

After issuing a command, this bit will be set, 
indicating that the HDC-1001 is busy executing a 
command. No other bits or registers are valid when 
this bit is set. 

&£.§&. EEE2E ESSlf *S£ Sill 

4. 6. 1 . DAM Not Found 

Will be set during a Read Sector command if, after 
successfully identifying the ID field, the Data Address 
mark was not detected within 16 bytes of ID field. 

4.6.2. TR000 Error 

Will be set during a Restore command if, after issuing 
1024 stepping pulses, the Track 000 line was not 
asserted by the drive. 

4.6.3. Aborted Command 

Indicates that a valid command has been received that 
cannot be executed, based on status information from 
the drive. For example, if a write sector command has 
been issued while the Write Fault line is set, the 
Aborted Command bit will be set. Interrogation of the 
Status and/or Error registers by the host can be 
performed to determine the cause of failure. 

4.6.4. ID Not Found 

When set, this bit indicates that mr\ ID field 
containing a specified cylinder, head, sector number or 
sector size was not found. 

4.6.5. CRC Error ID 

Indicates that a CRC error was encountered in »n ID 

field. 
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4.6.6. Uncorrectable 

Indicates that an error was detected while reading the 
data field or ECC check bits and the error was so 
severe that the controller was not able to correct the 
condition. 

4.6.7. Bad Block Detect 

Indicates that a Bad Block Mark has been detected in 
the specified ID field. If the command issued was a 
write sector command, no writing will be performed. If 
generated from a read sector command, the data field 
will not be read. Note that bad block will not be 
detected if the flaw is in the ID field unless multiple 
ID fields were written. 
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5. COMMANDS 



The HDC-1001 executes five easy to use macro commands. Most commands 
feature automatic * implied* seek, which means the host system need not tell 
the HDC-1001 where the R/W heads of each drive a^re or when to move them. 
The controller automatically performs all needed retries on all errors 
encountered including data field errors. If the data field contains an 
error, the controller will perform a correction, if possible. If the R/W 
head misposit ions, the HDC-1001 will automatically perform a restore and a 
re-seek. If the error is completely unrecoverable, the HDC-1001 will 
simulate a normal completion to simplify the host system's software. 

Commands are executed by loading a command byte into the Command register 
while the controller is not busy. (Controller will not be busy if it has 
completed the previous command.) The task file must be loaded prior to 
issuing a command. No command will execute if the Seek Complete or Ready 
lines are false or if the Write Fault line is true. Normally it is not 
necessary to poll these signals before issuing a command. If the HDC-1001 
receives a command that is not defined in the following table, undefined 
results will occur. 



19 



HDC-1001 HARD DISK CONTROLLER Technical Manual 



CQMMaMPJ 



S&is. £2QJE!40d Summary. 

For ease of discussion, commands are divided into three types which are 

summarized in the following table: 



TYPE 


1 
1 


COMMAND 


1 
1 


7 


& 


5 


BITS 
A 3 


£ 


1 


1 
1 


I 


1 


Restore 


1 











1 


r3 


rS 


rl 


r0l 


I 


1 


Seek 


1 





1 


1 


1 


r3 


rS 


rl 


r0l 


II 


1 


Read Sect or 


1 








1 





D 


M 


L 


1 


III 


i 


Write Sector 


1 








1 


1 





M 


L 


1 


III 


i 


Format Track 


1 





1 





1 











1 



L=Long Read /Write 
M-Multiple Sector 



D=DMA Read Interrupt 
rX=Stepping Rate 



5. 1. 1. Stepping Rates 



5. l.S. 









r3-r0 - 


- Stepp 


ing Rate 




1 




0000 


— 


35 uS 




1000 ■ 


A. mS 






0001 


s 


0. 5 mS 




1001 - 


A. 5 mS 






0010 


ss 


1.0 mS 




1010 - 


5. mS 






0011 


ss 


1.5 mS 




1011 - 


5.5 mS 






0100 


= 


2.0 mS 




1100 = 


&. mS 






0101 


ss 


£. 5 mS 




1101 " 


6. 5 mS 






0110 


= 


3. mS 




1110 - 


7. mS 






0111 


- 


3. 5 mS 




1111 - 


7. 5 mS 




DMA Read 

















D - DMA Read Mode 

* Programmed I/O Mode 

1 = DMA Mode 

The DMA bit is used to position INTRO in relation to 
DRQs during the read sector command. If the DMA bit is 
reset (D=0), the interrupt will occur before the first 
DRQ. This allows the programmed I/O host to intervene 
and transfer the data from the sector buffer. If the 
DMA bit is set (D=l), then the interrupt will occur 
only after the system DMA controller has transferred 
the entire buffer of data. 
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5.1.3. Long Read and Write 



If the Long bit is set, a special diagnostic read or 
write will be performed. During normal reads or 
writes, the ECC check bytes are not visible to the 
user. The Long bit allows the user to read and write 
these normally invisible bytes. 

During a Read Long, the HDC-1001 will return a sector 
that is four bytes longer than the selected sector 
size. These four bytes will be the ECC check bits as 
recorded on the disk. During a Write Long, the host 
give the HDC-1001 a sector that is four bytes longer 
than normal. These four extra bytes are recorded in 
place of the ECC bytes that are normally written after 
each sector. 

The Read and Write Long option may only be used when 
the HDC-1001 is in ECC mode. 



5&S&. lY.fi§ I QSBHfliiDds 

These commands simply position the R/W heads of the selected drive. Both 
commands have explicit stepping rate fields. The lower four bits of these 
commands form the stepping rate which is stored for later Read, Write or 
format operations. 

5. 2. 1. Restore 

The Restore command is used to calibrate the position of the R/W head on 
each drive by stepping the head outward until the TR000 line goes true. 
Upon receipt of the Restore command, the Busy bit in the Status Register is 
set. Cylinder High and Cylinder Low registers arm cleared. The lower 
four bits of the command byte are stored in the stepping rate register for 
subsequent implied seeks. The state of Seek Complete, Ready and Write 
Fault are sampled, and if an error condition exists, the Aborted command 
bit in the Error register is set, the Error bit in the Status register is 
set, an interrupt is generated, and the Busy bit is reset. 

If no errors are encountered thus far, the internal head position register 
for the selected drive is cleared. The TR000 line is sampled. If TR000 is 
true, ar, interrupt is generated and the Busy bit is reset. If TR000 is not 
true, stepping pulses at a rate determined by the stepping rate field are 
issued until the TR000 line is activated. When TR000 is activated, the 
Busy bit is reset and an interrupt is issued. If the TR000 line is not 
activated within 1B£4 stepping pulses, the TR000 Error bit in the Error 
Register and the Error bit in the Status Register are set, the Busy bit is 
reset, and an interrupt is issued. 
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5. 2. 2. Seek 

The Seek command positions the R/W head to a certain cylinder. It is 
primarily used to start two or more concurrent seeks on drives that support 
buffered stepping. Upon receipt of the Seek command, the Busy bit in the 
Status Register is set. The lower four bits of the command byte are stored 
in the stepping rate register for subsequent implied seeks. The state of 
Seek complete, Ready and Write Fault are sampled, and if an error condition 
exists, the Aborted command bit in the Error register is set, the Error bit 
in the Status register is set, an interrupt is generated, and the Busy bit 
is reset. 

If no errors are encountered thus far, the internal head position register 
for the selected drive is updated, the direction line is set to the proper 
direction and a step pulse is issued for each cylinder to be stepped. When 
all stepping pulses have been issued, the Busy bit is reset and an 
interrupt is issued. Note that the Seek Complete line is not sampled after 
the Seek command, allowing multiple seek operations to be started using 
drives with buffered seek capability. 



3a-3s. Iy.ee II Commands 



This type of command is 
the HDC-1081 buffer to 
fate as set by the last 



characterized by a transfer of a Clock ot data from 
the host. This command has an implicit stepping 
Restore or Seek command. 



5.3.1. Read Sector 

The Read Sector command is used to read a sector of data from the disk to 
the host computer. Upon receipt of the Read command, the Busy bit in the 
Status register is set. The state of Seek Complete, Ready and Write Fault 
are sampled, and i f an error condition exists, the Aborted Command bit in 
the Error register is set, the Error bit in the Status register is set, and 
a normal completion is simulated. 

Implied Seek 

If no errors ^re encountered so far, a Seek command is executed. The Seek 
Complete line is sampled. If the Seek Complete line does not go true 
within 128 Index pulses, then the Aborted command bit in the Error register 
is set, the Error bit in the Status register is set, and a normal 
completion is simulated. 

Retries 

Once the head has settled over the desired cylinder, the HDC-10IZI1 will 
attempt to read the sector. The HDC-1001 performs all retries necessary to 
recover the data during the read command. The controller attempts th- 
read the desired sector up to IS times. It will attempt a retry if it ces 
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not find an ID, if the ID of that sector has a bad CRC, if the Data Address 
Mark (DAM) couldn't be found, or even if the data was actually read from 
the disk but was in error. 

Error Correction 

If an error was detected while reading the data field, the controller will 
attempt to correct the error, If the error was correctable, the Corrected 
bit in the status register will be set and the command resumed. If it was 
uncorrectable, the Uncorrectable Error bit will be set, the Error bit in 
the Status register is set, and a normal completion is simulated. 

Auto Restore 

Every time the controller encounters an error, it records the occurrence of 
that error in an internal register. If, after 16 retries, the controller 
was not able to get a match on the ID field, it assumes that the head was 
possibly mis-positioned and executes an auto-restore. During the auto- 
restore, the stepping rate is implied to be equal to the Seek Complete 
period. If the TRK008 does not go true within 10£4 steps, the TRKO00 Error 
bit in the Error register is set, the Error bit in the Status register is 
set and a normal completion is simulated. 

After the auto-restore has been successfully completed, the controller re- 
seeks and attempts to read the sector once again. An auto-restore will be 
performed only once per read or write sector command. 

Hard Errors 

If the controller encounters a non-recoverable error, the controller 
examines its internal error history register. It then sets the bit in the 
Error Register of the highest severity error incurred. If the 
Uncorrectable bit is set, the data that last produced that error will be 
available in the sector buffer. The Error bit in the Status Register is 
set and a normal completion is simulated. 
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Error Severity Levels 

Although the HDC-1001 might encounter any number of errors in the course of 
executing a command, it only reports the most severe error. Errors are 
ranked from most severe to least severe as followst 

1. Aborted Command 

2. TR000 Error 

3. Bad Block* 

4. Uncorrectable 

5. Data Address Mark Not Found 

6. ID CRC Error 

7. ID Not Found 

* - Bad Block will only be detected if there is no ID CRC Error or ID Not 
Found Error in the sector with the Bad Block bit set. 

Normal Completion 

If the HDC-1001 encountered no errors, it is considered a normal 
completion. The busy bit is reset. The status of the DMA bit in the 
command byte is examined. If this bit is reset <D«*0; programmed I/O mode) 
then an interrupt is issued at this time. DRQs are then generated for each 
byte to be read from the buffer. (Note: It is recommended that programmed 
I/O transfers should take place as a block move without consulting the DRQ 
bit in the Status Register.) After all the data has been moved from the 
buffer, the DMA bit in the command byte is consulted again. If this bit is 
set (D=i; DMA mode) then an interrupt will be issued. 

5. 3.S. Multiple Sector Reads 

If the M bit in the command byte is set, then the HDC-1001 will attempt to 
read multiple sectors. After all the data has been transferred from the 
sector buffer to the host on a read, the Sector Number register is 
incremented, the Sector Count register is decremented, and if the Sector 
Count reaches zero or if a fatal error is encountered, the HDC-1001 will 
stop and interrupt the host. 

When a Correctable error is encountered during a multiple sector read, the 
occurance of the error is logged, but no interrupts are generated. After 
the whole multiple transfer is complete, the host can read the Corrected 
bit of the Status register to determine if any automatic corrections have 
taken place. 



Sjs-fia. lyES III Q203E!SDdS 

This type of command is characterized by a transfer of a block of data from 
the host to the HDC-1001 buffer. These commands have implicit stepping 
rates as set by the last Restore or Seek command. 
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5.4.1. Write Sector 

The Write Sector command is used to write a sector of data from the host 
computer to the disk. Upon receipt of the Write command, the controller 
generates DRQs for each byte to be written to the buffer. (Notes It is 
recommended that programmed I/O transfers should take place as a block move 
without consulting the DRQ bit in the Status register. ) 

After all data has been sent to the sector buffer, the Busy bit in the 
Status register is set. The state of Seek Complete, Ready and Write Fault 
are sampled, and if an error condition exists, the Aborted Command bit in 
the Error register is set, the Error bit in the Status register is set, an 
interrupt is generated and the Busy bit is reset. 

Ret r i es 

Once the head has settled over the desired cylinder, it will attempt to 
read the ID of the sector. The HDC-1001 performs all retries necessary to 
recover the Id during the write command. The controller attempts to read 
the ID of the desired sector up to 16 times. It will attempt a retry if it 
doesn't find ari ID or if the ID of that sector has a bad CRC. 

Auto Restore 

Every time the controller encounters art error, it records the occurrence of 
that error in an internal register. If, after 16 retries, the controller 
was not able to get a match on the ID field, it assumes that the head was 
possibly mis-positioned and executes an auto-restore. During the auto- 
restore, the stepping rate is implied to be equal to the Seek Complete 
period. After the auto-restore has been successfully completed, the 
controller re-seeks and attempts to write the sector once again. 

Hard Errors 

If the controller encounters a non-recoverable error, the controller 
examines its internal error history register. It then sets the bit in the 
Error register of the highest severity error incurred. The Error bit in 
the Status register is set, an interrupt is generated and the Busy bit is 
reset . 

If the proper sector is located, the sector buffer is written to the disk, 
an interrupt is generated and the Busy bit is reset. 



».£. Format Track 

Format Command is used for initializing the ID and data fields on a 
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particular disk. Upon receipt of the Format command, the controller 
generates ORQs for each byte of the interleave table to be written to the 
buffer. Information on setting up ar\ interleave table can be found in 
Section 7. In all cases, the number o* b/+«s transferred to the buffer 
must correspond to the current sector size. 

After all data has been set to the buffer, the Busy bi<- in the Status 
register is set. The state of Seek Complete Ready and Write Fault lines 
are sampled. If an error condition exists, the Pborted Command bit r the 
Error register is set, the Error bit in the Status register is set- an 
interrupt is generated and the Busy bit is reset. 



Implied Seek 

If no errors are encountered so far, a Seek command is executed. Mo 
verification of track positioning accuracy is performed because the t ck 
may not have any ID fields present. After the Seek operation 
performed, the Seek Complete line is sampled. If the Seek Complete 
is not asserted within 1S8 Index pulses, the Aborted Command bit in 
Error register is set, the Error bit in the Status register is set, 
interrupt is generated and the Busy bit is reset. 



has been 



the 

an 



Once the head has settled over the desired cylinder, the controller waits 
until the Index line is asserted. Once the index is found, a number of T D 
fields and nulled data fields are written to the disk. The number 

sectors written is equal to the contents of the Sector Count Register, 
each sector is written tne Sector Count Register is decremented, 
consequently, must be updated before each format operation. 



of 

As 
and 



After the last sector is written, the controller back-fills the track with 
4E' s. When the next index pulse after the last sector is written is 
encountered, the format operation is terminated, an Interrupt is generated 
and the Busy bit is reset. 



Track Format 

The Format command formats the track using the following format: 

REPEATED N TIME3 



I 



r 



GAP 

4 
UE) 



GAP 3 I MBYTES 
<4E> 



(00) 



v 

J— I 200 



(AM 



;ioenti 



CYL 
LOW 



SH 



SEC 



10 FIELD 



200 nS. MIN. IN0EX PULSE 



WRITE GATE 



CRC 
-2- 



3Bt 

(ooi; 1 



! :2 
BYTESl. 
(00) 



(AD 



(F3> 



0ATA 
F1£LD 



CRC'2) 

OR 
ECQ4) 



DAT AFIELD - 



3 BYTES 

(00) 



1 



NOTE: 

i) When MSB of SH byte - 1, bad block is 
detected. 

2) Write Gate turn-on is 3 bytes after the 10 field's 
CRC byte. 

3) Write Gate turn-off is 3 bytes after the Data 
Field's check bytes. 

4) , 1 2 by tes ot zeroes are re- written on a Data Field 
update. 



5) The 2 LSB'S of the »C£NT ryte are used 'or 
Cylinder high. 
These values are: 
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FE »o 255 
FF- 256 to 511 

?C - 512 to "67 
FD-7F.R'0 1023 



cylinders 
cylinders 
cylinders 
evtinoers 
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6. PROGRAMMING 



Users familiar with floppy disk systems will find programming the HDC-1001 
a pleasant surprise. A substantial amount of intelligence that was 
required by the host computer has been incorporated into the HDC-1001. The 
HDC-1001 performs all needed retries, even on head positioning errors. If 
there is an error in the data field, the HDC-1001 will attempt to correct 
it. Most commands feature automatic 'implied' seek which means that seek 
commands need not be issued to perform basic read/write functions. The 
HDC-1001 keeps track of the position of up to four read/write head 
assemblies, so the host system does not have to maintain track tables. All 
transfers to and from the disk are through art on-board full sector buffer. 
This means that data transfers are fully interrupt able and can take place 
at any speed that is convenient to the system designer. In the event of an 
unrecoverable error, the HDC-1001 simulates a normal completion so that 
special error recovery software is not needed. 

This section assumes that the user has read sections five (Task File) and 
six (Commands). 
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Before any of the five commands may be executed, a set of parameter 
registers called the Task File must be set up. For most commands, this 
informs the HDC-1001 of the exact location on the disk that the transfer 
should take place. For a normal read or write sector operation, the Sector 
Number, the Size/Drive/Head, Cylinder Number and Command register (usually 
in that order) will be written. 

Note that most of these registers are readable as well as writable. These 
registers normally are not read from, but this feature is provided so that 
error reporting routines can determine physically where an error occurred 
without recalculating the sector, head and cylinder parameters. 

Since the HDC-1001 can recall all the Task File parameters sent to it, it 
is recommended that Task File parameters be stored in the HDC-1001 as they 
are calculated. This will save the programmer a few instructions and 
microseconds by not maintaining two copies of the same information. 

6.1.1. Cylinders and Tracks 

Since most hard disk drives contain more than one head per positioner, it 
is more efficient to step the R/W head assemblies of most disk drives by 
cylinders, not tracks. In other words, the disk driver software should be 
designed to read or write all data that is directly accessible by all the 
heads on a positioner before stepping to a r^ew cylinder. The following 
example illustrates a cylinder-by-cylinder sequential file read on a four 
head, two platter disk drive: 



Physical 


1 Lc 


:=gical 


1 Physical 1 


Physical 


Cyl inder 


f Head Number 


1 Hear' Side ! 


Platter 


£5 


I 


3 


1 Top 1 


B 


26 


; 





1 Bottom 1 


ft 


26 


! 


i 


i Top 1 


« 


26 




2 


S Bottom 1 


B 


26 


i 


3 


I Top ! 


B 


27 


; 





! Bottom I 


A 



6i.2j_ lyfiS I Command Programming 

Restore and Seek are Type I commands. These commands position the R/W 
heads of the selected drive and set the implied stepping rate register. No 
data is transferred to or from the D'ta Register. To execute a Type I 
command, the system software must do the following functions in this order: 

1. Set up last' File s«d i <=s)"9 command with stepping rate' 
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(HDC-1001 will attempt to execute Type I command) 

2. Wait for interrupt or for Busy bit in Status Register to be reset 

3. Check Error bit in Status Register for proper completion. 

6.2.1. Stepping Rates 

Most drives that use the HDC-1001' s 35 uS stepping rate require a slower 
rate (usually 3 mS or more) for Restore operations. This is why the HDC- 
1O01 allows you to have explicit stepping rates on both Restore and Seek. 
Upon power up, it is good practice to issue a Restore command with a slower 
stepping rate to recalibrate the head assembly. After waiting for that 
operation to complete, issue a Seek command with the faster stepping rate 
to set the stepping rate for subsequent implied seeks. 

6. 2. 2. Use of Busy bit 

There are two different ways to sense the completion of a command. The 
first way, for smaller single user systems, is to poll the Busy bit of the 
Status Register. The Bus bit (bit 7) is set whenever the controller starts 
a disk operation and is reset whenever the controller is ready to 
communicate with the host computer. 

The HDC-1001 busy bit is located in the same place a the sign bit of many 
computers to simplify the polling process. 

This is one way to poll this bit using 8080 code: 

WAIT: IN STATUS ; Input HDC-1001, update sign flag 

ANA A 5 Update 8080 sign flag 

JM WAIT ;Wait if busy (sign) bit set 

6.2.3. Use of Interrupts 

Another more efficient way of notifying the CPU that the HDC-1001 has 
completed a command is through interrupts. The IIMTRQ line on the HDC-1001 
makes a low to high transition whenever the disk controller requires CPU 
intervention. This allows the host CPU to run other tasks while the HDC- 
1001 is reading or writing data to the disk. 

6. 2. 4. Use of the Error bit 

Since the HDC-1001 simulates normal completions, it acts the same whether 
or not errors are encountered. The only way to check error status is to 
check the Error bit in the Status register. The HDC-1001 Error bit is 
located so that it. can be easily tested by rotating it into the carry bit 
of many processors. The contents of the Error register are not valid 
unless the Error bit is set. 
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This is one way to check the Error bit using 8080 code: 



IN 

RAR 

JC 



STATUS 



ERROR 



j Get status <if not already in A) 
5 Rotate error bit into C 
;Jump i'f error found 



6.2.5. Use of the Corrected bit 

Correctable errors are usually quite benign and can almost always be 
ignored. However, some systems designers may wish to log their occurence. 
The Corrected bit is positioned in the Status register to facilitate error 
logging. Correctable and fatal errors can be detected with the following 
8080 code: 



IN STATUS 

ANI 5 

JNZ SOMERR 



; Get HDC-1001 status 
5 Mask off Error and Correct bits 
;Jump if we have either a correct- 
able or fatal error 



ia.3s. Iy.fi© 11 QsosfflSQd EceflESfflisioa 

The Read Sector command is the only Type II command. This command is 
characterized by the transfer of a block of data from the HDC-1001 buffer 
to the host. This command features implied seek with an implicit stepping 
rate. To execute a Type II single sector command in programmed I/O mode, 
the system software must do the following functions in this order: 

1. Set up Task File and issue command with DMA bit reset 

(HDC-1001 will attempt to read sector) 
£. Wait for interrupt or for Busy bit in Status Register to be reset 

3. Do block move from HDC-1001 buffer to system memory 

4. Check Error bit in Status Register for proper completion 



Note: 



Steps 3 and 4 above can be reversed. 



To execute a Type II single or multiple sector command in DMA mode with 
interrupts, the system software does the following: 

1. Set up Task File and issue command with DMA bit set 

2. Set up DMA controller 

(HDC-1001 will attempt to read single or multiple sectors) 
(DMA controller will move data from HDC-1001 to memory) 

3. Wait for interrupt from HDC-1001 

4. Check Error bit in Status register for proper completion 

Note: The above sequence is preferred but steps 1 and 2 above can be 
reversed. 

6. 3. 1. DMA Mode 

The DMA mode bit (D> in the above read sector examples is a special bit in 
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the command byte that is used to optimize the ... HDC-1001* s interrupts during 
programmed I/O and DMA operations. If the DMA bit is reset (D«0) the 
interrupt will come before the buffer is transferred. This allows a 
programmed I /b host to intervene and transfer the buffer of data. If the 
DMA bit is set <D=sl) then the interrupt will happen only after the data has 
been transferred. This allows the host to go uninterrupted until the 
entire buffer has been transferred. 



6. 3. 2. Block Moves 

The HDC-1001 performs all transfers between it and the disk drive through 
an on~board full sector buffer- Once the disk has been read, the data is 
available to the, host at any rate from DC to as high as a byte every 1.75 
uS. ...In programmed I/O applications there is no need to consult the DRQ bit 
in the status register to determine if another byte is ready to be 
processed. Once an interrupt occurs or the busy bit is reset on a read, 
the host computer should do a block move of all the bytes in the sector. 

The following 8080 code demonstrates a transfer from the HDC-1001 to system 
memory. The transfer address is in HL and the byte count is in B: 

jGet data from HDC-1001 sector buffer 

I St ore it in memory 

; Increment memory pointer 

^Decrement byte counter 

;Do it again if whole sector not xfered 

The following Z-80 instruction does it all. The transfer address is in HL, 
byte count is in B and HDC-1001 data register address in C: 

READIT: INIR {Transfer buffer from HDC-1001 to memory 

6.3.3. Using DMA 

There &r-e several features in the HDC-1001 which simplify the use of DMA. 
Of course, there's the DRQ line that makes a low to high transition for 
each byte to be transferred. As mentioned earlier, there is a special bit 
in the Read Sector command which optimizes the HDC-1001 interrupts for DMA 
operation. 

8.3.4. Multiple Sector Transfers 

The HDC-HZK91 can transfer more than one sector per command if interfaced 
using DMA §nd interrupts. Transfers as large as an entire track can be 
executed. The Sector Count register holds the number of records to be 
transferred. (If Sector Count is zero then £56 records will be 
transferred.) The Sector Number register holds the starting sector of the 
transfer. When a multiple sector transfer is successfully completed, the 
Sector Count register will be equal to zero and the Sector Number register 
will be equal to the last sector transferred plus one. 
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If a fatal error is encountered during a multiple sector transfer, the 

Sector Number register will be left pointing to the sector that contained 

the fatal error and the Sector Count register will hold the number of 
sectors that were not transferred. 

If a correctable error is encountered during a multiple sector read, the 
corrected bit in the Status register will be set but the operation will not 
be terminated because correctable errors are not considered fatal. 



Partial Sector Transfers 

The HDC*-1001 allows partial sector transfers on read operations. This 
allows the user to read the first part of a sector and then discard the 
rest. During programmed I/O, the byte counter in the block move routine is 
set to the number of bytes to be read. During DMA operations, the DMA 
controller is set with the number Of bytes to be transferred. 

Normally the HDC-1001 will interrupt the host after the sector has been 
transferred during a DMA read Operation, but if a partial sector has been 
read, the HDC— 1801 will not know that the operation has been completed. 
For this reason, the 'transfer complete* interrupt must come from the DMA 
controller. There is, still, a problem. During write sector operations, 
the DMA controller will interrupt the system after the buffer has been 
transferred to the HDC- 1001 but before the data has been written. Some 
systems with advanced interrupt handling capabilities can easily mask off 
the spurious DMA interrupt. For those that can't, the HDC— 1001 has a 
provision built into its command structure to detect read operations. 

Interrupt Source Selection 

Bit 4 of all commands determines whether the operation will be a read 
sector operation or something else. Those commands that require the 
interrupt from the HDC-1001 have this bit set to a 1, The read sector 
command (the only one that might need the DMA controller's interrupt) has 
this bit set to a 0. 

Clearing Hardware DRQ 

During partial sector reads, the DMA controller will stop the DMA transfer 
before the HDC-1001 has a chance to issue its last data request. Because 
of this, the DRQ line may be set the next time transfer parameters »re sent 
to the DMA controller. To avoid spurious (and often fatal) DRQ' s, the user 
must do a hardware clear of the DRQ line. This is accomplished by reading 
or Writing the Cylinder Low register. (This will only clear the DRQ 1 ine. 
The DRQ bit in the Status Register will be indeterminate.) This action is 
typically done before a subsequent read or write sector command in the 
normal course of updating the Task File. Care should be exercised to insure 
that the DMA controller has passed its parameters only after the Task File 
is updated. 
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6.3.5. Simulated Completions 

fill HDC-1001 commands (except multiple sector transfers) act in precisely 
the same manner, whether or not an error was encountered. The only way to 
detect that &n error has occurred is to sample the Error bit in the Status 
Register. Simulated Completions offer the system designer several tangible 

benefits. > 

o Simplifies masking and generation of interrupts 

o Simplifies non-error handling portions of the system software 

o Eliminates the software overhead of handling different types of errors 

o Simplifies system software error handling validation (any error is 
handled the same as any other error) 

o Prevents system failure in the event of some obscure error condition 
that the system programmer did not anticipate 



§.&.&:. IY.E§= L1L itfSmmand. Programming 

Write Sector and Format are Type III commands. These commands mre 
characterized by the transfer of a block of data from the host to the HDC- 
1001 buffer. Like Type II commands, these commands feature implied seek 
with an implicit stepping rate. To execute a single sector Type III 
command in programmed I/O mode, the system software must do the following 
functions in this order: 

1. Set up Task File and issue command 

£. Do block move from system memory to HDC-1001 buffer 
(HDC-1001 will attempt to write a sector or format) 
3. Wait for interrupt or for Busy bit in Status Register, to be reset 
4« Check Error- fait in Status Register for proper completion 

To execute a single or multiple sector Type III command in DMA mode with 
interrupts, the system software does the following: 

1. Set up Task File and issue command 

2. ■ Set up D!*fA controller 

3. Wait for interrupt from HDC-1001 

4. Check Error bit in Status Register for proper completion 

h -'ots! Steps 1 and £ above tiar> be reversed. 
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6. A. 1. For mat ti nQ 

The format command is very similar to the write sector command, except 
instead of filling the sector buffer with user data, it is filled with 
interleave and bad block information. Two bytes will be written to the 
buffer for each sector to be formatted. 

■ ■ ■ i ■ 
The first (lower) byte will be either a 03 or an 80 in hex. If the lower 
byte is a 00, the sector is marked as good. If the lower byte is an 80, 
the sector will set the Bad Block bit in the Status Register if there is 
any attempt to read or write to it. Please see cautions in section on bad 
block mapping. 

The second (upper) byte is the logical sector number of the next sector to 
be formatted. This number will be recorded on the disk. The Sector Number 
register is not used during Format. 

On a 3£ sector per track disk, 32 pairs of formatting information must be 
supplied to the drive during each format operation. To start the format 
operation the buffer must be completely filled, even if the sector table is 
not as long as the buffer. On a 32 sector per track disk, 64 bytes of 
formatting information are supplied. If the sector size is 256 bytes then 
192 bytes of garbage must be passed to the controller to start the format 
operation. 

Since the contents of the sector buffer do not imply how many sectors are 
to be formatted, a dedicated register is provided. This Sector Count 
register must be loaded with the number of sectors to be formatted before 
each and every format operation. To calculate the maximum number of 
sectors per track, see Appendix C. 

6.4.2. Interleaving 

i 

If we try to read physically sequential sectors on the disk, there is not 
enough time for us to set up to read or write the next sector before it has 
passed by the read/write head. This means that the disk will have to make a 
complete rotation to pick up the n»Ht sector. If we were to read all 32 
sectors on a particular track it would,, take 32 rotations, or about a half a 
second per 8K bytes. This performance can be tremendously improved by 
allowing the system to read or write more than one sector per rotation. 
This can be accomplished with interleaving. 

Suppose our system takes less than three sector times (3/32 rotational 
period with 256 byte sectors) to digest the data that it has read and to 
set up the next read operation. That means that if we can arrange to have 
the second logical sector placed physically only four sectors away from the 
first one, the controller will be able to read it without much delay. This 
four to one interleave factor will allow us to potentially read the entire 
track in only four rotations. In our particular example, this will 
increase the throughput be a factor of eight. 

The simplest way to determine the optimum interleave for any particular 
system is through experimentation. If the system maintains its directories 
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or virtual memory swapping areas in a certain place 
sometimes makes sense to have more than one interleave. 



on 



the disk, it 



To simplify driver software, the HDC-1001 will automatically map logical to 
physical sectors to achieve interleave. This logical to physical map is 
recorded on each track of the disk in the ID fields of the sectors. This 
map is recorded on the disk during the format operation. Here is an 
example of an interleave table for a 3£ sector track with ^n interleave 
and no bad blocks: 



Interleave table with 3S sectors and 4:1 interleave 



00 


00 


00 


08 


00 


10 


00 


18 


00 


®i 


00 


09 


00 


11 


00 


19 


00 


02 


00 


03 


00 


IS 


00 


lfl 


00 


03 


00 


0B 


00 


13 


00 


IB 


00 


04 


00 


0C 


00 


14 


00 


1C 


00 


05 


00 


0D 


00 


15 


00 


ID 


00 


06 


00 


0E 


00 


1G 


00 


IE 


00 


07 


00 


0F 


00 


17 


00 


IF 



Remember: The balance of the buffer must be filled with something to start 
the format operation. 

The first byte in each byte pair in the preceding example is set to 00 
This marks each block as a 'good' block. The second byte of each byte pair 
is the logical sector number. The first byte pair abov? represents "• l 
first logical sector of the track. The underlined byte pair represents the 
second logical sector. 

§s.Sa. l*d il2£k Magging 

The Winchester and thin film technology drives that interface to the HDC- 
1001 often do not have perfect media. Imperfections in the media allow much 
more latitude in what the media manufacturers can ship, significantly 
bringing down the cost of the media and, consequently, the drives. 

The user is required to map out these imperfections. There are many ways 
it can be done, some of which are highly operating system dependent. Here 
are a few ideas: 



8.5.1. Sector Pre-al location 



If the operating system supports random sector or group allocation, the bad 
blocks can sometimes be mapped out by recording an un-deletable file using 
all the bad sectors on the disk. When the operating system tries to write 
to the bad block, it will see that the sector or group that contains the 
error has already been allocated, 
map over the bad sector. 



The operating system will automatically 



Thet^e are a couple of minor restrictions associated with this form of bad 
block mapping. The file that contains the bad sector must newer be moved 
to another section of the disk. The bad sector f ile 'r>av not ce read (for 
obvious reasons) and reads or write to the disK, that -.'o not consult tne 
disk allocation map (physical reads/writes), are >»et showed. 
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6.5.2. Alternate Tracks 



This method works on most operating systems but, it requires more software 
overhead. Whenever a read or write is attempted, the track number 
(cylinder and head select) is checked against a table maintained by the 
operating system or driver. If the track number matches the table, the 
driver knows that there is a flaw somewhere on that track. The driver will 
look up the alternate track for that flawed track and the read or write 
will be performed elsewhere. 



The primary disadvantages of this type of bad block mapping is its rather 
high software overhead. When the system is brought up, the alternate track 
table has to be read from some flawless areas of the disk. After it has 
been read, every read or write operation must check the alternate track 
table before performing its respective operation. 

The HDC-1001 bad block marking and detection facility is useful for 
eliminating the software overhead of looking up each track number before 
each write is performed. During format, all the sectors of the bad track 
should be written redundantly with the bad block bit set (See section on 
Bad Block bit below). When any read or write is attempted on the bad 
track, the HDC-1001 will interrupt with the Error bit in the Status 
register and the Bad Block bit in the Error register set. The driver c^n 
then look up the alternate track in its internal table and resume the 
operat ion. 

6.5.3. Spare Sectors 

This method is probably the simplest to implement in most systems. Its 
primary disadvantage is that at least one sector must be set aside as a 
spare for each track. During format, the physical sector that contains the 
flaw is written with some illegal sector number. The physical sector 
following it contains the real logical sector and its data. In the 
following interleave table, the user mapped out the fifth physical sector 
by telling the HDC-1001 to write a logical sector number of FF to it. 



Interleave table with 32 sectors and 4:1 interleave with physical 
five mapped out : 



sector 



00 


00 


00 


08 


00 


10 


00 


IS 


2® 


EE 


00 


01 


00 


09 


00 


11 


00 


19 


00 


02 


00 


0A 


00 


12 


00 


1A 


00 


03 


00 


0B 


00 


13 


00 


IB 


00 


04 


00 


0C 


00 


14 


00 


1C 


00 


05 


00 


0D 


00 


15 


00 


ID 


00 


06 


00 


0E 


00 


16 


00 


IE 


00 


07 


00 


0F 


00 


17 



Please note that when formatting the disk in this manner, at least one 
sector must have art illegal sector number. Also, since we have allocated 
one sector to bad block mapping, we no longer have z secto IF. 



6.5.4. Bad Block Bit 
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The HDC-1001 Allows the user to set a marker that is recorded into the ID 
field. When the HDC-1001 attempts to read or write a sector with a bad 
block mark set, the operation will be aborted and the Error bit in the 
Status register and the Bad Block bit in the Error register will be set. 
The Size, Head, Cylinder, Sector and ID CRC fields of the selected sector 
must be correct in order to detect the bad block mark. 

To insure that the Bad Block bit can be read even though some ID fields may 
be defective, the ID fields must be recorded redundantly. In order to make 
this possible, the HDC-1001 includes a special variation of the Format 
command. When a Bad Block bit in the interleave table is set during 
format, the HDC-1001 records only the ID field of that sector. No data 
field is recorded. This helps to make room for redundant ID fields. 

In the following interleave table the user has marked all the sectors with 
a bad block mark and recorded all sectors redundantly. The interleave is 
not very important here because the driver (hopefully) will not attempt to 
read bad sectors sequentially. 



Interleave table with redundant sectors, 
marked as bad blocks: 



no inter lea vi 



an all sectors 



80 


00 


80 


01 


80 


02 


80 


03 


80 


04 


80 


05 


80 


08 


80 


07 


80 


08 


80 


09 


80 


0fi 


80 


0B 


80 


0C 


80 


0D 


80 


0E 


80 


0F 


80 


10 


80 


11 


80 


12 


80 


13 


80 


14 


80 


15 


80 


16 


80 


17 


80 


18 


80 


19 


80 


1ft 


80 


IB 


80 


1C 


80 


ID 


80 


IE 


80 


IF 


80 


00 


80 


01 


80 


02 


80 


03 


80 


04 


80 


05 


80 


06 


80 


07 


80 


08 


80 


09 


60 


0ft 


80 


0B 


80 


0C 


60 


0D 


80 


0E 


80 


0F 


80 


10 


80 


11 


80 


12 


80 


13 


80 


14 


80 


15 


80 


15 


80 


17 


80 


18 


80 


19 


80 


1ft 


80 


IB 


80 


1C 


80 


ID 


80 


IE 


80 


IF 
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7. THEORY OF OPERATION 



Zs.it §£QS£fil 

The HDC-1001 hard disk controller is a discrete implementation of all 
functions required to control SA1000/ST50& compatible Winchester hard disk 
drives via the S-100 bus. The controller is fabricated using a mix of 
high-speed bipolar and NMOS devices contained on a single, S-sided PC 
board. The design of the circuitry makes use of a high-speed 
Microcontroller, the 8X300, newly developed NMOS support devices, Schottky, 
and low power Schottky devices to achieve low component count and low cost 
while maintaining high performance and reliability. All I/O connections are 
made using standard ribbon cable connectors. Standard pin-out 
configurations for disk interface connectors are provided to permit direct 
pin-for-pin connection to SA1000 compatible 8". drives and ST506 compatible 
5-1/4" drives. All power for the board can be supplied from a single +8 
Volt power supply. All host to disk data transfers are buffered by an 
onboard RAM to achieve totally asynchronous transfers to and from the disk 
by the host. In addition, the HDC-1001 has the ability to perform error 
correction <ECC) using firmware and a custom designed NMOS device. 

The HDC-1001 is available in two different formats - a 5-1/4" or 8" board. 

The disk controller is built around 5 basic sections: 

1. Processor functions 

£. Serial data separation 

3. Data conversion, checking and correcting 

4. Serial data generation 

5. Host interface functions (S-100) 



Z&Ss. B£2£S2B2£ EUDSiiSDS 

fill functions of the HDC-1001 controller are[ ultimately control led by the 
onboard processor. Due to the high data rates associated with hard disk 
drives, processing of data and control of machine functions* within the 
circuitry requires a processor capable of extremely fast execution speed. 
The processor used is the 8X300, a bipolar microcontroller, particularly 
well suited for handling data efficiently at high rates. 

The 8X300 is operated at a basic clock rate of 8 MHz and perform *v all 
operations within 2 clock cycles, giving it a speed of 4 MIPS (Million 
Instructions Per Second) or one instruction executed every £50 nS. The 
architecture of the processor is different from most popular 
microprocessors in that no common data or address bus is provided to be 
shared by RAM, ROM or peripheral devices. 

Instructions are fetched from ROM via a dedicated instruction address and 
data bus. The instruction address bus (IA13-IA0) is capable of directly 
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accessing 8K words of program storage. The HDC-1001, however, uses only 
the first 10 address lines, limiting onboard program storage to IK words. 
Program data is input to the 8X300 on the Instruction Data Bus (ID15-ID0) 
as 16 bit words which are decoded to perform the desired operation. All 
bus designations utilized by the 8X300 are reversed, from the traditional 
LSB to MSB weighting. On the HDC-1001 these lines have been renamed on the 
schematic, using traditional weighting to provide a more conventional 
designation system for the board. 

Data is transferred between the processor and it ports on a separate 8-bit 
bus called the "10" bus. This bus is active low. It must be noted that 
this bus is in no way related to the instruction data bus and should be 
thought of as simply art 8-bit bi-directional 10 bus for the 8X300. In fact, 
it has been renamed as 100-107 to reflect this definition. 

7. £. 1. Fast 10 Select 

An extension byte has been added onto the instruction data memory to 
provide port access decoding on an instruction by instruction basis. This 
"Fast 10 Select" byte is not processed by the 8X300? rather it is decoded 
by auxiliary hardware to provide 8 read strobes, ,8 write strobes, and 8 
single bit output ports which route data to the various devices distributed 
along the 10 bus. 

The write part of the Fast 10 byte is latched into a 4-bit latch and the 
input of a decoder/latch on the trailing edge of MCLK. This ensures that 
data remains stable during the entire instruction. The read strobe and 
write strobe are selected through a pair of l-of-8 decoders which are 
alternately enabled by the SC- control strobe produced by the 8X300. 

It also provides latch-address data to the addressable latch for drive and 
ECC control signals. To provide edges on read strobes during sequential 
read operations from various ports, the read strobe decoder is always 
disqualified at the end of instruction by MCLK-. Because each decoder has 
a unique input and the latch is directly addressable, it is possible to 
select any read port with any write port, during each instruction. 

7. 2. 2. Internal Bus Control 

Several bus control signals are produced by the 8X300 to identify and 
strobe the data on the 10 bus. SC- is a signal which determines the 
direction of the data to and from peripherals. When SC- is false, (during 

the first half cycle) the 8X300 inputs data -fron fche 10 bus. When SC- is 
true (only during the second half cycle), the 8X300 outputs data to the 10 
bus. The HDC-1001 allows 8-bit immediate data movss from the 8X300 to any 
output port within one instruction, instead of the normal 5~bit immediate 
moves provided for by the instruction set. 

All instruction fetches occur late in the second cycle of the preceding 

instruction. This time is marked by the generation of a 65 nS (nominal) 

active high pulse called MCLK, which occurs every instruction. On some 

ports, MCLK is also used to latch data prior to being input on the 10 bus 
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to insure stability during reads, and to disqualify read strobes which 
would otherwise remain true into the second clock cycle of any instruction 
which does not write to a port. 

All I/O ports on the 8X300 &ra logically divided into two address spaces. 
This address space is qualified with RIGHT BANK SELECT (RB-). All HDC-1001 
I/O ports, except RAM, appear in the left bank address space. The RAM is 
placed in the right bank and the right bank signal is run directly to the 
CS- inputs of the RAMs to avoid the propagation delays associated with the 
Fast I/O Select logic. This allows slower RAMs to be used and provides 
better access margins on read operations. 

7. 2. 3. Reset Circuit 

The 8X300 is held reset for approximately 40 mS after initial power-on. 
This is accomplished by an RC network <R£4:R5, C24:C16 and CRlsCRl) which 
drives a Schmitt trigger to provide a proper rise/fall time on the RESET- 
line of the 8X300 and various port latches. Alternate reset of the HDC- 
1001 can be accomplished by asserting MR- whenever the host wishes to reset 
the controller. A Schmitt trigger is provided with a 4. 7K pull-up to 
buffer the MR- input from the host. RESET- also propagates to the drive 
control latches, the host interface Support Logic Chip, and the INTRQ and 
DRQ latches. 

7.2.4. Processor Power Supply 

Power is supplied to the 8X300 from the +5 Volt <vcc> power bus. Due to 
the internal operation of the 8X300, Art on-chip voltage reference is 
provided, to produce bias to an external pass transistor which drops Vcc to 
the 8X300 to approximately +3.0 Volts. This supply is used internally by 
the 8X300 logic and all signals of the 8X300 are internally level shifted 
to be TTL compatible. 

7.2.5. Read and Write Ports 

Throughout the circuit, output ports consist of D type latches using write 
strobes (WR0-7) to latch data into the ports. Reading of ports is 
accomplished by using read strobes RD0, RD£, and RD4-6. The read strobes 
individually enable selected tri-state output devices on the 10 bus. 
Additionally, two read strobes are used to clock the host DRQ «"d INTRO 
latches for instructions not requiring data from a port. This ensures 
glitchl ess operation of the Fast 10 port decoders. 

7.2.6. Read/Write Memory 

Since the 8X300 does not permit data to be saved or retrieved from 
dedicated program storage, RAM must be installed on the 10 bus and it must 
be accessed via the 10 bus by I/O instructions like all other port 
accesses. To provide for addressing the RAM, three latch /counters are 
connected to the 10 bus to receive and store addresses required to access 

' ■ . ■■■■'■■. ■ ' . 
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the RAM. 

RAM Addressing 

The RAM address bus (RA0-RA9) uniquely addresses 1024 memory locations. As 
each counter chip reaches a count of 0, it will set a borrow condition to 
the next higher counter which will be decremented at the end of the next 
access to RAM. When all bits of the address have been reset, the ROVF- bit 
on the last counter will be reset, providing un overflow status which can 
be read by the processor. By setting various beginning address values, 
ROVF- can be used to mark the end of any RAM access loop from 1 to 1034 
bytes in length. In the HDC-1001 this function is used for setting sector 
buffer lengths of 128, 256 and 512 bytes in the normal mode and 132, 260, 
516 in the long mode. 

Sector Buffering 

All data read from the disk or written to the disk is passed through the 
RAM to provide buffering required for asynchronous data transfer between 
the host and disk. The counters are post-decremented so that addresses are 
stable to the RAM by at least one instruction prior to the actual access. 
This preselection feature effectively reduces RAM access time to the output 
enable and propagation time of the RAM for read operations and the width of 
the minimum WR- strobe pulse for write operations. 

RAM Accessing 

RAM access is initiated by RB- which is output by the 8X300. Data to be 
read from RAM will be placed on the 10 bus whenever RB- is low and SC- is 
high. Data is written into a selected RAM cell on the trailing edge of SC- 
if RB- is low. During writes, RB- will be low for at least 120 nS so that 
data setup time requirements are met. 

Scratchpad Operations 

Because the RAM address counters are preset table direct reads and writes to 
a specific address are possible. However, resolution of the address is 
limited to the nearest fourth address location. this limitation is imposed 
so that a full ten bit address can be specified with a single eight bit 
output. The least significant two bits are implied to be 10 (binary). 

7.2.7. Miscellaneous Control Ports 

Control of the various functional sections of the HDC-1001 is accomplished 
by a dedicated 6-bit control port called the MAC CNTRL and an addressable 
latch. MAC CNTRL enables the functions of the WAIT control circuitry 
(WAEN-), ECC generation (ECCIZ-), gating of read data into data separation 
circuitry (RSATE), selection of read or write functions (WRITE-), control 
of ECC check word output (1BLA-), and AM detection (SRCH). MAC CNTRL 
output states &re latched into the port by a write strobe (WR7). 
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The addressable latch controls drive functions and CRC/ECC selection. This 
latch enables direction of the drive (DIRIN-), stepping pulses to the drive 
(STEP-), reduced write current (RWC-), write precomp (WPC-) , write enable 
(WRITE GATE-), and switching the enable between CRC and ECC (CRC-/ECC). 

fill remaining ports are distributed among the basic functional sections of 
the HDG- 18)01 and will be described in detail within the discussion of those 
functions. 

2a.3i. Ser ial Da.t a §*bse*£ i SD 

The HDC-1001 controller utilizes an NMOS device (WD1100-09) especially 
designed to process incoming MFM data from the drive by a process called 
data separation. Here, some background information may be helpful i 

In order to provide maximum data recording density and storage 
efficiency, data is recorded on the disk using a Modified 
Frequency Modulation (MFM) technique. This technique requires 
clock pits to be recorded only when two successive data bits are 
missing in the serial data stream. This reduces the total number 
of bits required to record a given amount of information on the 
disk. This results in an effective doubling of the amount of data 
capacity, hence the term "double density." 

Because clock bits are not recorded with every data bit cell, circuitry is 
required that can remain in sync with data during the absence of clock 
bits. Synchronous decoding of MFM data streams requires the decoder 
circuitry to synthesize clock bit timing when clocks »re missing and 
synchronize to clock bits when they are present. This is accomplished by 
using a phase locked oscillator employing &n error amplifier/filter to sync 
onto and hold a specific phase relationship to the data and clock bits in 
the data stream. The synthesized clock called RCLK c»r\ then be used to 
separate data bits from clock bits and to shift the resultant serial data 
into registers for byte parallel izat ion. 

7.3.1. Incoming Data Selection 

In the HDC-1001, serial data is input from up to 4 radially connected 
drives via a quad RS-42S differential receiver. The receiver converts 
differential input data to TTL levels for use by the controller. The data 
from the selected drive is then routed to the data separation circuitry by 
a 4-section AND/OR/INVERT gate. Due to the fact that different drives 
produce varying data pulse widths, the data is first routed through a one- 
shot to provide a consistent data pulse width. At this point data and 
clocks are still combined and appear as 50 nS nominal active high pulses 
spaced at intervals of 1, 1-5 or £ times the RCLK period. This data is 
presented to the Data Separator chip (U6;U34) which will then gate either 
MFM data or a reference clock into the first stage of the VCO error 
amplifier circuitry. 
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7. 3. £. Reference Clock 

The reference clock is derived from the write clock crystal oscillator <and 
associated circuitry). This oscillator uses a fundamental crystal cut to 
oscillate at 4 times the RCLK frequency. The 4X output is then divided by 
U4 to produce both a SX clock (SXDR) WsfeicTi in «sed as a reference and a IX 
clock (WCLK) which is used to produce t^W write data for the disk. The 
crystal (YD frequency is SO. 000 MHz for STSJSS compatible drives or 17.360 
MHz for SO 1000 compatible drives. 

7.3.3. Clock Gating 

The gating of the reference and MFM data into the data separator is 
dependent on the condition of the read gate (RGATE) signal and the spacing 
of the data on the serial stream after RGATE is brought true. Due to the 
techniques which are employed to separate data from clocks, it is necessary 
to run the VCO at a rate twice the data clock (RCLK) rate. The VCO is set 
to a open loop frequency of SX RCLK. Any variations in this rate" due to 
variations in disk rotational speed must be compensated for by the VCO, but 
instantaneous shifts in data due to the effects of adjacent bit cells on 
the disk and minor noise must be ignored. Also, the response of the VCO 
must be adjusted to effectively ride over missing clock bits which occur as 
a result of the MFM recording technique. The resultant compromise between 
response and reject requirements of the VCO cause the VCO to have a 
tendency to become locked onto harmonics of the data rate rather easily. 
This is likely to occur if the VCO is connected to a data stream over a 
field of data which has data bits spaced at 1.5 or £ times the actual RCLK 
time intervals. 

To provide protection against this undesirable condition, the VCO is always 
held locked onto a stable clock running at 2X RCLK frequency whenever the 
controller is not actually reading data. Care is, taken to switch in read 
data to the VCO error detector only when it is known that the data stream 
frequency is equal to the RCLK frequency. This can occur only when the 
data is a solid stream of all ones or all zeros. 

7.3.4. High Frequency Detector 

The switch from reference clock to live data is initiated immediately after 
the RGATE goes true and will only occur after 16 consecutive ones or zeros 
(high frequency) are detected on the raw MFM. This detection is 
accomplished by a one-shot and the data separator. The one-shot is 
adjusted for a pulse width of 1.S5 times the RCLK period (£5® +/-10 nS for 
ST506 compatible drives and £87 + /-10 nS for SA1000 compatible drives). 
The adjustment of the one-shot provides tolerance of up to 1/4 RCLK period 
in jitter on the MFM data bits while still being able to distinguish MFM 
zeros or ones from other data patterns. 

Each clock or data bit on the serial stream triggers the one-shot. If the 
time between successive triggers is less than the one-shot time constant, 
the one-shot remains retriggered. As the one-shot is triggered by data 
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he 8X300 to determine the condition 



fit this point data and clocks have finally been connected to the first 
stage of the data separator. The heart of the data separator is the VCO, 
the error amplifier, filter and the Data Separator Support Logic Chip 
(WD1 100-09). 

7.3.5. Sample on Phase Detection 

When an input signal is applied to the system, its phase relationship is 
detected within the Data Separator Device. The function of this phase 
detector is to provide windows, during which the leading edge of the 
incoming MFM data can be compared to the leading edges of the VCO clock. 
The windows are approximately 50 nS in length. The windows are initiated 
by the leading edge of any data bit as it enters the detector. They are 
terminated by that same data bit, edge delayed by 60 nS or the VCO output 
(OSC-). When both the delayed data bit (delayed by DL1) and the nearest 
VCO edge arrive at the detector, the detector is reset until the next data 
bit arrives on the MFM data stream. The delayed data bit sets its half of 
the detector latches to produce a pump up condition at the error amplifier. 
The VCO clock edge set its half of the detector to produce a pump-down 
condition. When the circuit is balanced, both pumps are on or off, 
producing no net pump-up or pump-down. 

7.3.6. Error Amplifier 

Control of the VCO is accomplished by the error amplifier, filter, and Data 
Separator Chip. The error amplifier is a balanced current mirror, whose 
output sources or sinks current to the filter stage. Whenever the VCO is 
running too slow, the error amplifier receives pulses from data bits before 
pulses from the VCO clock. This causes the error amplifier to produce 
pump-up pulses to the filter. The filter integrates these pulses, 
producing an average increase in the voltage to the VCO. Whenever the VCO 
is running too fast , the error amplifier produces pump-down pulses to the 
filter. It must be noted, however, that some slight error will always be 
present because, without pumps, the filter will float and the VCO will 
drift. The overall gain of the error amplifier and the VCO will maintain 
this error very small, resulting in very close tracking between the VCO 
output phase and the incoming data phase. 

7.3.7. VCO 

The HDC-1001 uses a single chip VCO, which simplifies circuitry and 
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adjustments. The operating point of the VCO is initially set by adjusting 
the variable capacitor for a 10 Mhz (when running on 5 Mhz drives) output 
center frequency and the frequency control voltage input to £. 5ft +/-©. 5V. 
It should be noted here that the frequency range voltage and the frequency 
output are adjusted to the ' locked' center frequency with the same variable 
capacitor adjuster. 

The output of the error amplifier and filter is fed to the VCO and 
represents how far the VCO frequency is from that of the incoming signal. 
The error signal, which is proportional to the difference, allows the VCO 
frequency to shift from center frequency and become the same frequency as 
the input signal. When the loop is in lock, the difference frequency 
component (error voltage) is DC and will be passed by the low pass filter. 
Thus, the lock range is limited by the range of the error voltage that can 
be generated. The lock range is essentially a DC parameter and is not 
effected by the band edge of the low pass filter. It can be defined as the 
frequency range, usually centered about the VCO initial free running 
frequency, over which the loop can track the input signal once lock has 
been acquired. 

Frequency control is actually a matter of frequency range. The difference 
component may fall outside the band edge of the low pass filter and be 
removed along with the sum frequency component. If this is the case, no 
information is transmitted around the loop and the VCO remains at its 
initial free running frequency. As the input frequency approaches that of 
the VCO, the frequency of the difference component decreases and approaches 
the band edge of the low pass filter. Now, some of the difference 
component is passed, which tends to drive the VCO towards the frequency of 
the input signal. This, in turn, decreases the frequency of the difference 
component and allows more information to be transmitted through the low 
pass filter to the VCO. This is essentially a positive feed-back, which 
causes the VCO to snap into ' lock' with the input signal. With this in 
mind, the term 'capture range' can be defined as the frequency range 
centered about the VCO initial free running frequency over which the loop 
can acquire lock with the input signal. 

fts previously stated, the VCO runs at a frequency twice that of the RCLK 
rate. By setting the center frequency equal to twice the data rate, the 
VCO will lock to the data and give an exact synchronized clock. 

7.3.8. Window Extension 

Once the VCO has been locked onto the phase of the incoming data, the 
actual separation of data and clocks can occur using a technique called 
window extension. This technique causes data bits to first have their 
leading edges shifted into the center of the RCLk half cycles and then to 
be latched or extended until the next rising edge of the RCLK. The delayed 
data clocks a pair of latches. The 'data' latch has its D input and CLEAR 
connected to +RCLK and the 'clock' latch has its D input connected to 
RCLK-. 

If an MFM data bit enters the latches while RCLK+ is high, it will be 
extended as a data bit. If RCLK- is high, it will be extended as a clock 
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bit. Due to this extension technique, bits can jitter approximately 1/4 the 
RCLK period without being lost. The output of each latch is then further 
extended by feeding directly into another stage of latches and clocked on 
alternate edges of RCLK. The final' outputs of the data 
ex tens ion/ separation stage are two separate signals, one consisting solely 
of NRZ data, and the other NRZ clocks. NRZ data and clocks are finally in 
a form suitable for processing by subsequent circuitry within the HDC-1001. 

7.3.9. Clock Detection 

Due to the nature of MFM data encoding, it is impossible to know exactly if 
MFM bits are data or clocks. This ambiguity results in having to assume 
that bits on RCLK- are actually data bits until the VCO is locked on and a 
unique data/clock pattern is detected. This is accomplished by holding the 
VCO to RCLK divider reset until it is fairly certain that bits on the data 
stream are actually clocks belonging to a field of zero data. 

Once this assessment has been made, the processor releases the AM detector 
by raising the SEARCH signal. This signal releases a latch which will 
remove DHOLD- from the RCLK divider on the next rising edge of a MFM data 
bit so that CLOCKS will be on the RCLK- phase and DATA will be on the RCLK+ 
phase. The processor makes its assessment of the state of the data stream 
solely on the one-shot in the DRUN circuit. Once released, the phase of 
RCLK versus data and clocks will remain stable throughout the read of an ID 
or data field. Whenever SEARCH is dropped, the VCO to RCLK divider is once 
again reset and no RCLKS are produced. 

2a.4a. Baia SsoygcsisD sb£ £b.eckinja 

MFM data which has been separated to form NRZ data and clocks are processed 
through specialized circuitry to prepare it for parallel processing by the 
8X300. This processing consists of 3 functional circuits. 

1) AM detection 

2) ECC/CRC checking circuit 

3) Serial to Parallel Conversion 

Each function will be discussed separately but bear in mind that many 
interdependencies exist. 

7.4.1. AM Detection 

As previously stated, it is impossible to know whether serial data bits are 
actually data or clock bits by just looking at the data stream. Also, it 
is equally impossible to determine byte boundaries of the data stream. 
This problem is solved by a uniquely recorded data/clock pattern called an 
Address Mark (AM). The AM consists of a data pattern of hexadecimal 'Al' 
with a missing clock pattern of hex ' OA' . Normally a data byte of hex 'Al' 
requires a clocking pattern of hex ' OE' . 



The AM is used to uniquely identify the start of a field of information 
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(Data or ID field) within each sector. Preceding each AM on the disk there 
is always a long run of ' zero' data. Zeros have a clock bit for every 
RCLK. When attempting to read information from the disk, the HDC-1001 
first acquires phase lock over a field of zeros. After this acquisition is 
achieved, the processor releases the AM detector by raising the SEARCH 
control line (SRCH) on the MAC CNTRL port. Due to the circuitry associated 
with the VCO to RCLK divider the RDAT- output of the data separator will be 
high and the CLKS- output will be low. RCLK- will be the shifting clock 
for RDAT- and RCLK+ will be the shifting clock for CLKS-. These 4 signals 
are routed into the AM detector. 

Inside the AM detector, the RDAT- is shifted into an 8-bit synchronous 
serial shift register and clocked on the falling edge of RCLK-. CLKS- are 
shifted into a similar shift register on the falling edge of RCLK+. The 
output stage of the RDAT- register is dumped into an 'Al» comparator and 
the output stage of the CLKS- register is dumped into a ' 0A» comparator. 
AM detection occurs when both detectors are true, setting the AMDET latch. 
At the instant AM occurs, the exact relationship between data and clocks is 
known. It is also known that data is being clocked by RCLK- so CLKS- can 
actually be discarded? its only purpose was in detecting AM. The AMDET- 
signal is used as a synchronization signal to start subsequent conversion 
circuitry. The AMDET- signal remains true until the processor again de- 
asserts the SEARCH control line. 

The AMDET- signal is processed by a D latch, located in the Support Logic 
device (WD1100-07), to precisely time the leading edge of AMDET- to the 
rising edge of RCLK. This synchronization relaxes timing requirements 
on the data and clock inputs of the serial to parallel converter. Also, a 
one-bit delay is placed in the AMDET path within the Support Logic Device 
to compensate for correct timing with the ECC architecture. 

7.4.2. Error Detection and Correction 

Data recorded on magnetic media is prone to several types of errors which 
could render data unusable if some form of error detection were not 
employed. 

On the HDC-1001, error detection is performed on all data transfers from 
the disk. The ID fields use a 16 bit Cyclic Redundancy Check <CRC) and the 
data fields use either the same CRC or a special 32 bit Error Correction 
Code (ECC). The CRC and ECC fields are appended to the data field that they 
are to protect. 

The HDC-1001 uses the same device to generate and cheek CRCs and ECCs. 
Normally, the HDC-1001 uses CRCs in ID fields and ECCs in data fields. 
Also, as a software selectable option, the HDC-1001 may be used in a CRC 
only mode by appending CRC check bytes to both ID and Data fields. 
Although either polynomial could be used for both fields, the use of the 
ECC polynomial is limited to data only. On-the-fly correction of ID fields 
cannot be done and CRC provides adequate checking for the ID fields. The 
ECC and CRC polynomials used are as follows; 



47 



HDC-1001 HARD DISK CONTROLLER Technical Manual IHgQBY. 8E QBSB9JIQN 

ECC « X**31+X**28+X**26+X»M9+X*»17+X**10+X*»6+X#*2+1 

CRC -■ X**16+X**12+X»*5+l (Also known as CRC-CCITT) 

As data is being read from the disk, the CRC/ECC generator re-computes the 
original check bits. After all the data are read the value in the CRC/ECC 
generator is exclusive ORed with the check bits recorded on the disk. The 
result is called the syndrome. If the syndrome was zero, the data was 
correct ly, read. Otherwise, an error occured. If the field was protected 
by a CRC, the data can often be recovered by a retry which the HDC-1001 
performs automatically. If the field was protected by an ECC, the non-zero 
syndrome is used by the on board processor to compute the displacement and 
the error vector within the sector. This information is then used to 
correct the data if a single burst of no more than five bits in error 
occured. 

The CRC/ECC generator is initialized by setting ECCIZ- low for at least 250 
nS during the search for the AM. ECCIZ- is originated on the MAC CNTRL 
port. Upon receiving the ECCIZ- signal, the ECC generator will preset all 
32 of its internal polynomial division shift registers to logic ones and 
arm an internal latch which will start the CRC/ECC generator on the leading 
edge of the first non-zero bit (hopefully an AM) . to enter the device. 

Once enabled by the first non-zero data bit, the ECC device will shift 
succeeding data bits into a feedback shift register string with exclusive 
OR gates tied to the feedback nodes of the register. As each RCLK occurs, 
the registers will divide the incoming data and a unique pattern of ones 
and zeros will appear across the registers. The ECCEN input line is set 
low, indicating that the internal circuitry is ready to begin the 
computation of the ECC/CRC check bytes. 

Sometime before the last byte of data and after the next to the last byte 
of data is transferred through the device, the DCSS line is set low. When 
the last bit of an ID or data field is processed, the pattern in the 
registers should be equivalent to the 16 or 32 check bits appended to the 
fields during original recording. The check bits on the disk are exclusive 
ORed with the check bits in the CRC/ECC device to produce the syndrome. 

Data is deserialized after being processed by the ECC/CRC device and Byte- 
Sync boundries are marked by byte-sync pulses obtained from the Data 
Support logic device on the RBS input. The byte-sync pulses are internally 
ANDed with the RWCP line to insure the smooth transition of check/syndrome 
bytes on the DOUT output line, after the last bit of data has been entered 
into the device. A one-bit time delay occurs on the DOUT line because an 
internal latch is used to deglitch the output line. 

7.4.3. Serial to Parallel Conversion 

After data has been processed by the ECC device, the Serial to Parallel 
Converter takes over. NRZ data and RCLK are used to shift data bits into 
an 8-bit serial to parallel shift register. As each bit is shifted, a 
divide-by-8 counter circuit is incremented. After every eighth bit of data 
is shifted, the counter produces an overflow pulse, marking byte boundaries 

i 
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in the serial data stream. The overflow bit from the counter resets the 
counter, clocks the data from the shift register into an 8-bit parallel 
latch, and sets a tri-state flag register called BDONE. The flag can be 
read by the processor to see if any converted data is ready to be read from 
the latches. 

When the processor sees BDONE in the true state, it services the device by 
gating data onto the 10 bus using read strobe 4 (RD4-) in conjunction with 
a tri-state buffer. The act of reading the latches also clears the BDONE 
flag. As successive bytes are processed, BDONE is serviced by the 
processor as data becomes available. 

Z«.3s. Iscisl Data OansCfiilSD 

The HDC-1001 records data on the disk in MFM format. In order to produce 
the proper data format, the HDC-1001 uses several specialized devices to 
process the parallel data supplied by the host into a serial MFM data 
stream. The data supplied by the host is temporarily stored in the buffer 
RAM until the correct sector is located for the data to be written. 

The process of writing is essentially the opposite of reading except that 
the data separator circuitry is not required and the generation of the MFM 
data stream is produced by synchronous clocking techniques. 

The functional sections of the serial data generation section are listed 
below: 

1. Parallel to Serial conversion 

S. ECC/CRC generation 

3. MFM and precompensat ion 

7.5.1. Parallel to Serial Conversion 

Parallel data is converted into a serial NRZ data stream by the Parallel to 
Serial device. The processor enables this conversion by lowering the 
WRITE- signal on MAC CNTRL. WRITE- causes the tri-state buffers present on 
the parallel to serial device to become active, supplying the ECC device 
with data, clocks, and BDONE strobes. 

The processor presents parallel data on the 10 bus along with the WR4- 
write strobe which latches the data into the parallel port on the trailing 
edge of the strobe. The write strobe also resets any pending BDONE. 
Inside the parallel to serial device, the parallel latches are loaded into 
a serial shift register on every eighth WCLK transition. As the data is 
transferred to the shift registers, the BDONE status flag is set. The 
processor reads this flag to determine when to write the next parallel byte 
to the device. The timing of the parallel accesses is at a rate 1/8 that 
of the bit rate of the NRZ data stream. For ST506 compatible drives the 
byte timing is 1.6 uS and for SA1000 drives it is 1.84 uS. 

The output of the last register in the shift string is brought out of the 
device as NTZ serial data. 
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Whenever it is desired to write a repetitive string of identical data 
bytes, the processor can simply ignore the BDONE flag and permit the device 
to reload the data from its latches over and over again for as long as 
required to generate the field. This feature of the device is used in 
writing certain fields used in formatting. 

7.5. S. CRC/ECC Beneration 

The CRC/ECC generator /checker is used to generate the CRC/ECC bits and to 
append them to the end of the data being written to the disk. The 
operation of the polynomial generator is identical to read operations 
except that at the end of the data field the processor sets a" signal which 
causes the device to output the computed CRC/ECC after the data instead of 
producing the syndrome. 

The initial states of the shift registers within the device &rB forced to 
all ones by the processor pulsing ECCIZ- for at least 250 nS while the 
parallel to serial device is outputting all zeros on the NRZ data line. fit 
that time, a latch is set which holds the registers at ones until the first 
non-zero data bit enters the device. 

The first non-zero bit will be the MSB of the AM (hexadecimal Al> of the 
data field to be written. When the processor decides that enough zeros 
have been written to satisfy the sync field requirements, it will store a 
hex fll in the parallel to serial device. At the proper time (in sync With 
BDONE) the parallel to serial device will begin to send the MSB of the AM 
to the CRC/ECC device. This will start the CRC or ECC polynomial generator 
and the ECC will be computed. 

To write the ECC/CRC check bits, the processor will assert the One Byte 
Look-Ahead (1BLA-) signal on MAC CNTRL port just after the last data byte 
was sent to the parallel to serial converter. The internal switch over 
from data to check bits is synchronized to the next byte time by the WCP- 
signal. Once the switch takes place, the CRC/ECC generator will begin 
dumping the computed CRC or ECC onto the NRZ data stream. The net effect 
of this is to append the proper CRC or ECC information to the end of a 
field of data. 1BLA- is maintained true for the duration of the unloading 
process which lasts for up to four byte times. 

During the unloading process, the ECC registers back-fill with zeros. This 
feature is handy because by leaving 1BLA- low for additional time, zeros 
will always be written after the CRC or ECC which is a requirement of the 
format of the disk. The NRZ data from the CRC/ECC device is sent to the 
MFM generator device. 

7.5.3. MFM Generation 

The conversion from NRZ write data to MFM write data takes place in the 
MFM/Precomp device. This device accepts NRZ data and a complimentary WCLK 
and produces MFM data and clocks by sending the data through circuitry 
which decides when - and where to write clocks on the data stream under the 

i 
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MFM encoding rules. The proper encoding of the data into MFM requires the 
device to apply three rules to the data. 

1) If the current data cell contains a data bit 
then no clock bit will be generated. 

2) If the previous data cell contained a data bit 
then no clock bit will be generated. 

3) If the previous data cell and the present data 
cell are vacant then produce a clock bit in the 
current clock cell. 

The terms 'data cell' and 'clock cell' are defined by the state of the 
WCLK. While WCLK is low it is a data cell and while high it is a clock 
cell. It can be seen then, that both clock and data cells are 1/S the 
period of WCLK or 100 hS for ST506 compatible drives and 115 nS for SA1000 
drives. Also, note that by the rules stated above, a clock and data bit 
can never occur within the same WCLK period and legal spacings for bits can 
be 1, 1.5, or S times the WCLK period only. The rules are implemented 
within the device by shift registers that hold the next two, last and 
present data bits and combinatorial logic. The state of WCLK is considered 
and the appropriate bit cells are filled and combined on the MFMW output 
line of the device. 

Write Precompensat ion 

The MFM data stream is now totally compatible with the recording rules and 
may be sent to suitable line drivers for transmission to the drive except 
for one modification. Due to the decreasing radius on the physical surface 
of the disk, the inside tracks have less circumference and therefore 
exhibit an increase in recording flux density over the outside tracks. 
This increase in flux density aggravates a problem in magnetic recording 
know as 'dynamic bit shift. ' 

Dynamic bit shift comes about as the result of one bit on the disk (a flux 
reversal) influencing an adjacent bit. The effect is to shift the leading 
edge of both bits closer together or further apart than recorded. The net 
result is that enough jitter is added to the data recorded on the inside 
tracks to make them harder to recover without error. 

Write precompensat ion is used to reduce the effect of dynamic bit shift. 
It is a way of predicting which direction a particular bit will be shifted 
and intentionally writing that bit out of position in the opposite 
direction to the expected shift. This done by examining the next two data 
bits, the last and the present bits to be written and producing three 
signals depending on what these bits are. The three signals are EARLY; 
LATE and NORMAL. They are used in conjunction with a delay line to cause 
the leading edge of a data or clock bit to be written earlier, later or on 
time. 

The processor can enable or disable the generation of these signals by 
controlling the Write Pre-Comp (WPC) line from the addressable latch. When 
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WPC is high, precomp is in effect. When WPC is low, no precomp is 
generated and the nominal output of the device is held true. 

The delay line actually performs the precomp with the help of an 
AND/OR/ INVERT gate. MFMW pulses are applied to the input of the delay 
line and depending on which of the three precomp signals is present the 
AND/OR/INVERT gate selects a different tap on the delay line. Nominal data 
is actually tapped from the second tap. Early data from the first and late 
data from the third. From the AND/OR/ INVERT gate the MFMW data is sent to 
the input of An RS-4S2 driver where it is converted to a differential form 
and then is sent to the drive. 

Zi-is. Host Interface 

The source or destination register inside the HDC-1001 is selected by 
accessing the address of the desired register. Since the access time for 
any particular read or write operation will vary, the HDC-1001 provides a 
not ready signal (WAIT-). For systems using interrupts and/or DMA, the 
HDC-1001 provides INTerrupt ReQuest (INTRQ) and Data ReQuest (DRQ). 

7.6.1. Wait Enable 

Since most of the registers in the HDC-1001 are not implemented in 
hardware, it takes the 8X300 a finite amount of time to actually fetch the 
requested data on a read or store data on a write. This time varies 
depending on the amount of processing the 8X300 must do to access the 
desired register. After the data has been written or read, the HDC-1001 
de-asserts the WAIT- line, allowing the host to terminate the current bus 
cycle. 

The generation of the WAIT- signal is controlled by a bit in the MAC latch 
called WAit ENable <WAEN-> . If the HDC-1001 is ready to accept 
random accesses to its task file, WAEN- will be asserted. The leading edge 
of CS- clocks the wait line (Support Logic Chip) transferring the WAEN- 
state through the chip. This clocking action is required to insure that 
WAIT- will not be asserted in the middle of any bus access already in 
progress. After the wait latch has been clocked, CS- causes WAIT- to be 
asserted to the host. 

The WAIT- line is released on the trailing edge of any read or write strobe 
to the communications latch. This release is caused by the logical OR of 
RD6- and WR6- which presets the wait latch to a non-wait request condition. 
The WAIT- signal is stretched to the trailing edge of the RD6- or WR6-. 

If WAEN- is de-asserted, the HDC-1001 generates no waits at all. In this 
case, the host will read the dummy status written to the communications 
latch by the 8X300. This feature is used by the microcode to simulate a 
busy condition when the host reads the status register in non-interrupt 
driven systems. When the HDC-1001 becomes un-busy, the WAEN- line will be 
asserted and operations on the host interface bus will be monitored once 
again. 
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The S-100 pin that receives the wait- line is selected by the jumper at 
location G. Gl-£ is for selecting XRDY-, G2-3 is for selecting PRDY-. 

7.6.2. Bus Gating 

During all accesses by the host, one of two signals will be produced to 
gate the bus. During read operations, CS- and RE- are ANDed, producing Bus 
Output Control (BOC-). This signal gates the contents of the communication 
latch onto the DAL bus. During write operations, CS- and WE- produce Bus 
Input Control (BIO. This signal latches the state of the DAL lines into 
ari internal R/S latch. 

7.6.3. Register Selection 

The combination of a host read or write operation along with the WAEN- 
signal being asserted, causes a signal, Card Select ACcess (CSAC), to be 
generated. The 8X300 samples this signal every 250 nS, and if asserted, 
reads the status of A0-2 and WE-. The state of A0-2 and WE- determine 
which register is to be accessed <A0-2> and in what direction that access 
will take place. 

7.6.4. Interrupts and DRQs 

The HDC-1001 produces INTerrupt ReQuests (INTRQ) to signal the end of all 
disk operations and Data ReQuests (DRQ) to signal data ready to DMA 
controllers. INTRQ and DRQ originate on the MFM generator as an auxiliary 
function of the chip. Interrupts are cleared by HSAC- (Host Select Access) 
and A0, Al when the host reads the Status register, issues a command, or 
accesses the Sector Number register. DRQs aY^e cleared when the host 
accesses the Data or Cylinder Low registers. DRQs will be re-issued for 
each byte to be transferred. HSAC- is a 200 nS version of the CSAC- 
signal, which is produced by the Data Separator Support Device (WD1100-08). 
During Powei — On Reset or Master Reset (MR-), INTRQ and DRQ are reset. 

The destination of INTRQ- is selected by jumper area H as shown in table 
be 1 ow : 

VI0 VII VI2 Vli ~VI4 VI5 VI6 VI7 INT 
Position 1 23 4 5 67 8 9 

7.6.5. Address Select 

The address at which the HDC-1001 board responds on the S-100 bus is 
determined by the address switches (U16. ) Switches 1 through 5 select the 
upper 5 bits of the address (A7-A3) which the HDC-1001 acknoledges. A 
closed switch equals a 1 and an open switch equals a for that address 
line. 
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7. 6. 6. Boot Prom 

The HDC-1001 has provisions for a power on 2716 boot prom. This prom is 
enabled on power up by jumper E2-3. If selected and jumper F is installed 
it will assert phantom to disable other memory in the system. The prom is 
disabled by the first access to any HDC-1001 task register. If the prom is 
not needed for booting jumper E should be in location El-2. 
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8. MAINTENANCE 



The HDC-1001 requires no scheduled preventative maintenance. There are 
three adjustments associated with the data separation circuitry that may' 
need to be adjusted if a drive with a different data rate is installed. 

The HDC-1001 is available in two different ways, the HDC-1001-8 for 8" 
drives and the HDC- 100 1-5 for 51/4" drives. 
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Stla. QByN Adjustments 

To facilitate the process of acquiring phase lock on data being read from a 
disk, a hardware detector is utilized to indicate when the read/write head 
of the drive is over a recorded field of all ones or all zeros. The 
detector depends on the timing of a one-shot <U4) which is adjustable by 
the DRUN pot <R14>. DRUN must be adjusted according to the following 
procedures: 

The DRUN adjustment is made with the HDC-1001 in &r> operating test 
configuration with a host, drive and power source. 

Monitor DRUN- <U4 pin 7:) with a 10X oscilloscope probe while attempting 
to read a sector of data from the drive. The scope should be set to 
trigger on a high to low transition. While observing DRUN-, adjust R14. 
The period of the DRUN single shot should be adjusted to l.SS times the 
period of RCLK. 

Disconnect all test equipment. 



I Yl:&2 Frequency I DRUN Period I Freq. Range I Final Setting I 



+- 



-+- 



I £0.000 Mhz I 250 nS t 9.0-11.0 MHz I 10.0 Mhz +/-1 KHz I 

+_ . — + + + + 

I 17.360 Mhz I £80 nS ! 7.5- 9.5 MHz I 8.68 Mhz+/-1 KHz I 



Sa-ia. Qssiilaisc EcsgysDsy 

Data separation circuitry on the HDC-1001 uses a voltage controlled 
oscillator (VCO) which phase locks onto incoming data and provides a clock 
suitable for separating data and clock bits on an MFM encoded data stream. 
The VCO must be adjusted using the following procedures s 

Set Balance potentiometer R4 to 100 Ohms +/- 5 Ohms. This is a rough 
balance adjustment. 

Connect a frequency counter to the VCO buffered output on U£ pin 10. 

Connect a Volt meter to the Center Frequency input of U£ pin 1. 

Make all connections to the board, including the host and drive. Adjust 
the variable capacitor C£3 until the frequency output locks onto the 
desired center frequency for the drive being used which is 10.000 MHz for 
ST506 or 8.68 MHz for SPI1000. Once this ' locked -on' frequency is achieved, 
continue the same adjustment for an input voltage of £.5 +/-0. 5 V. 
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The balance adjustment fine tunes the relationship of delayed data (DLYDAT) 
to read clock (RCLK). 

Attach channel 1 of a dual trace oscilloscope to U6, pin £ (RCLK). Set 
scope for 20 nS/div, with a positive slope. Attach the other channel to 
U6, pin 3 (DLYDAT). 

While the controller is doing constant reads to a single sector, adjust the 
potentiometer R4 so that the edge of DLYDAT is moving to the right with 
respect to RCLK. When the HDC-1001 starts encountering errors, move the 
RCLK signal to the left until the HDC-1001 starts to function again. Note 
the exact position of DLYDAT on the screen in nanoseconds. We will call 
this the "right capture value. " 



"RCLK-" 



"DLYDAT" 



1 \ 

I \ 

I \ 

-I 

/ 
/! 
./ I < — Right Capture Value 
I 



Continue moving DLYDAT to the left until the HDC-1001 fails again. Move 
DLYDAT to the right until the controller functions again. This is the left 
capture value. 



I 



I 



"RCLK-" / 
/ 

/ I 

Left Capture Value — > I 

I 

1/ 
/ 
"DLYDAT" /I 

_/ I 



Right Capture Value 
I 
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The final adjustment for the HDC-1001 is determined using the following 
formula: 

(left capture value-right capture value) X 0. 7 ■ Final adjustment value 
Adjust pot to final adjustment value. 



Left Capture Value — -> 



"RCLK" 



"DLYDP.T" 



/■ 






I < — Right Capture Value 
I — I— \ 

I \ 
70* | < \ 

I V 

I 

I . 

1/ 
/ 
/I 
/ I 



I 



Final Adjustment 



Re-adjust variable capacitor CS3 until a value of 2.5 volts appears on the 
voltmeter. 

Remove all test equipment. 
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A. DISK DRIVER EXAPMLE 



Sometimes an example is worth a thousand words. Hopefully, these sample 
disk drivers will be the catalyst to get your first driver running. Note 
that even though these drivers are very simplistic, they represent 
everything needed to satisfy the HDC-1001 operating requirements. As you 
might notice, there is no retry software included in these examples. That 
is because the HDC-1001 does all needed retries. 

Two examples are presented. The first is a programmed I/O, programmed 
status driver using the eight bit Intel 8085 microprocessor. The second 
example is programmed I/O and interrupt driven and is written for the 
sixteen bit Western Digital WD16 microprocessor. 
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Qa.ii. Bsllsd s$.atu§ Bciyfic 



*****************************#*#**4Ht**#******; 

HDC-1001 Hard Disk Controller Driver { 
Example for 6085 Microprocessor ; 

with programmed I/O and polled status | 
********************************************* { 



{This driver is intended to demonstrate one simple approach to writing a 
; driver for the HDC-1001. It assumes that the HDC-1001 is interfaced using 
{programmed I/O without interrupts. 



;The specifications of the imaginary demonstration drive ares 



{Sector size: 
{Sector per Track: 
{Surfaces per drive: 
{Cylinders per drive: 
{Stepping rate: 
STRGTE ■ £ 



256 bytes 

33 

4 (two platters) 

512 

2 milliseconds 

{Define stepping rate for assembler 



{Since we're allowing the HDC-1001 to map around the bad blocks for us, we 
{have to sacrifice one sector per track. This brings down the logical 
{sector per track count to 32. 

{Experienced systems programmers will note that we are not making our 
{drive as flexible as it should be. Since HDC-1001 compatible drives will 
{be introduced in the future and present manufacturers will be increasing 
{the density of their current drives, the driver that you write should be 
{built with plenty of equates and conditional assemblies. 

Our imaginary operating system can access up to 65536 logical records of 
£56 bytes each. It has three types of calls: Initialize, Read and Write. 
Three numerical parameters are passed in the following registers: 

Drive number C 

Logical record number DE 
Transfer address HL 

Upon completion of all commands, the carry bit of the 8085 will be reset 
if the operation terminated properly, and set if there was an error. If 
there was an error during read or write, the error handling routine will 
decode it and print it out on the user console. 
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• #♦*♦»*#»*#*******»*»♦*♦ 5 
; Equates { 
; *♦*»»#♦♦*♦#****»♦♦»#**♦ ; 



5*** 


Port 


Definition * 


BASADD 


ss 




0C8 


DATA 


ss 




BASADD 


ERROR 


= 




BASADD+1 


UPC 


= 




BASADD+1 


SECNT 


a 




BASADD+2 


SECNO 


sb 




BASADD+3 


CYLLO 


- 




BASADD+4 


CYLHI 


as 




BASADD+5 


SDH 


s 




BASADD+6 


STATUS 


"SB 




BASADD+7 


COMND 


S 




BASADD+7 


{*** 


Command 


Definition 


REST 


:=S 




10 


READ 


SS 




£0 


WRITE 






30 


A. 1.1. 


Initia 


lization 



**# 



; Base address of HDC-1001 

; Data register 

; Error Register 

{Write Precomp 

; Sector Count 

; Sector Number 

f Cylinder Number 

{Cylinder High 

-.{Size /Head /Drive 

{Status register 

; Command register 



*** 



{Restore command 

;Read command (programmed I/O mod 

;Write command 



!e> 



{ ************************* 
{ INITIALIZATION 
I************************* 

{This routine is called once whenever the system is powered up or reset, 
{It sets the stepping rate and restores the head on the selected drive. 

UPTASK {Select drive, don't care about record 
A, REST+ <STRATE*2> {Bet stepping rate and restore 
COMND {Output command to HDC-1001 

STATUS {Wait *till restore done 
A {by updating sign flag in 8085 

RSWAIT {and wait *tili bit 7 (Busy) goes low 

{Put error bit in carry 
; Ret urn to operating system 



RESTORs 


CALL 




MVI 




OUT 


RSWAIT s 


IN 




ANA 




JM 




RAR 




RET 
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A. 1.2. Read Sector 

5 ft***************** ; 

; READ j 
{*♦**#»♦**♦*»***#»*} 

;This is the read routine for our imaginary operating system. 

READITj CALL UPTASK jUpdate HDC-1001 task file 
MVI A, READ j Bet READ command 
OUT COMND ; Out put command to HDC-1001 



?Wait for HDC-1001 to read 
RWAIT: IN STATUS 
ANA A 
JM RWAIT 



in a sector 

{Check Busy bit 

t by Updating sign flag in 6085 

j and wait * till bit 7 goes low 



; Transfer sect 


or from HDC-1001 


; (Transfer address in HL) 


MVI 


B, 


READLPs IN 


DATA 


MOV 


M,A 


I NX 


H 


DCR 


& 


JNZ 


READLP 


IN 


STATUS 


JMP 


DONE 



to system memory 

;Init byte counter to E56 bytes 

;Get a byte of data from HDC-1001 

I Move it to memory 

; I ncr ement memor y pointer 

; Decrement byte counter and continue 

;if we haven't transferred £56 yet 

j Re-read status for errors 

;Now check the completion status 
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A. 1.3. Write Sector 



******************* 

WRITE 
******************* 



;This is the write routine for the driver 

WRITIT: CALL UPTASK ;Update HDC-1001 task file 

MVI A, WRITE ;Get WRITE command 
OUT COMND ; Out put command to HDC-1001 

; Transfer sector from system memory to HDC-1001 

; (Transfer address in HL> 

;,Init byte counter to £56 bytes 

5 Get a byte of data from memory 

;Move it to HDC-1001 

{Increment memory pointer 

; Decrement byte counter and continue 

;if we haven't transferred 256 yet 

;Wait for HDC-1001 to write the sector 

WWAIT; IN STATUS 5 Check Busy bit 

ANA A ;by updating sign flag in 8085 

JM WWAIT ; and wait 'till bit 7 goes low 





MVI 


B,0 


WRITLPs 


MOV 


A, M 




OUT 


DATA 




INX 


H 




DCR 


B 




JNZ 


WRITLP 



DONE 



;Both READ and WRITE commands finish here to check for errors 
DONE: RAR ; Rotate Error bit to cairry 

RNC ;and return to OS is no error 

IN ERROR ;6et HDC-1001 error code 

j<<< Place error reporting routine here) > > 



STC 
RET 



;Set carry to flag art error 
;and return to OS with error 
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A. 1.4. Task Fi la Updating 

5 UPTASK SUBROUTINE ; 

;This subroutine sets up the task file registers 



1 Sect or number 




UPTPSK: MOV 


A,E 


PNI 


31. 


OUT 


SECIMO 


j Size/Drive/Head 




MOV 


ft,E 


RLC 




RLC 




RLC 




PNI 


.3. 


MOV 


B, P 


MOV 


A, C 


PDD 


P 


ADD 


A 


PDD 


P 


PDD 


A 


ORA 


B 


ORI 


SO 


OUT 


SDH 


{Cylinder low 




MOV 


P, E 


RPL 




MOV 


A,D 


RPL 




OUT 


CYLLO 


jCyl inger high 




MVI 


A, 


RAL 




OUT 


CYLHI 


RET 




END 





5 Get lower 7 bits of record number 
jMask off lower 5 bits (bits 1-4) 
5 and send to sector number register 



; Get lower 8 bits again 

; Rotate remaining 3 bits 

; to- get &n effective right shift of 5 

;Mask off next two bits <5-6> 

;to make head number 

;and store it away momentarily 

;Get drive number 

;and left shift it by 3 



;0R in head number and 

jOR in ECC flag and size field 

; send it to Size/Drive/Head register 



;Get last bit of lower record number 
;and put it in carry 
;Get upper half of record number 
5 Left shift it and merge in carry 
;Send it to lower cylinder register 



; Clear all bits except for the 
ft he least significant and send 
;to the upper cylinder register 
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B. INTERLEAVE CALCULATING UTILITY 



This BASIC program simplified the process of generating interleave tables. 
It is written in a fairly standard subset of the BASIC language and should 
run on many BASIC interpreters and compilers. Some implementations of 
BASIC may require the variable names to be converted to single letter names 
and the IF THEN ELSE constructs may have to be re-written. 

The two questions at the beginning of the program should be answered in 
decimal. The interleave is printed in hexadecimal. - 
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ia-ia. §9§I£ iDiSEleivg Calcu.lat.ing Program 

10 PRINT"HDC-1001 Interleave calculating program" 

20 PRINT 

30 INPUT"Nurnber of sectors?" ; COUNT 

40 INPUT" Interleave Factor?" ; INTER 

50 DIMHEX*( 16), SECTOR (COUNT) > 

60 FOR INDEX-1 TO 16 

70 READ HEX* < INDEX ) 

80 NEXT 

90 FOR INDEX=1 TO COUNT 

100 SECTOR < INDEX) =1 

110 NEXT 

115 RES?=0 

1£0 FOR INDEX=0 TO COUNT-1 

130 IF RES) "COUNT THEN RES»RES-COUNT 

140 IF SECTOR (RES+1)=-1 THEN SECTOR (RES+1 ) "INDEX ELSE RES=RES+1 :GOTO 130 

150 RES»INTER+RES 

160 NEXT 

170 PRINT 

180 PRINT" Interleave table with" ; COUNT? "sectors and" ; INTER? " : 1 interleave" 

190 FOR INDEX=1 TO COUNT 

£00 X=INT (SECTOR (INDEX)/ 16) 

210 PRINT HEX*(X+1) ;HEX* (SECTOR( INDEX) -X*16+l ) , 

220 NEXT 

230 PRINT 

240 DATA 0,1,2, 3, 4, 5, 6, 7, 8, 9, A, B, C, D, E, F 

250 END 
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C. SECTOR CALCULATING UTILITY 



HDC-1001 compatible disk drives are constantly changing. Higher bit 
packing densities and higher accuracy spindle motors help to increase the 
amount of data that can be put on a track. This appendix will help you to 
determine the maximum number of sectors that can be recorded on your disk 
drive. 

The unformatted byte capacity can be figured from this formula: 

Capacity=Bits per second / Revolutions per second x (1-Error) / 8 

We'll take a hypothetical drive (the same one as in the disk driver 
examples) with a data rate of 5M bits per second and revolution rate of 
3&O0 RPM. Our drive has a spindle speed accuracy of 3*. These numbers 
applied to our formula yield: 

10, 104»5, 000, 000/60X ( 1-9. 03) /B 

To be on the safe side, we will always round down when we come up with a 
fractional value. The unformatted capacity of this drive is 10,104 bytes. 
To figure the number of sectors per some number of bytes apply this 
formula. 

Sectors=Capacity / (Data field size+Gap3+Check bytes+Other overhead) 

Using 51S byte sectors with a Gap3 size of 30 bytes, running ECC we end up 
with: 

17=10, 104/(512+30+4+41) 

The BASIC program on the next page CArt be used to automate the sector per 
track calculations presented here. 
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Ga.i&. IQilC §ss£s£s esr Icasi* utility 

10 PRINT "HDC-1001 Sectors per Track Calculating Utility" 

20 PRINT 

30 INPUT"Data rate of drive in bits per second: ";DATARATE 

40 INPUT "Revolutions per minute: ";RPM 

50 INPUT "Rotational speed error in percent: ";RERROR 

60 CAPACITY=INT(DP,TARATE/RPM*60*(1-RERROR/100)/S) 

70 PRINT "Unformatted capacity is " CAPACITY" by t es. " 

80 PRINT 

90 INPUT"Data field size in bytes <1S8, £56, etc. >:";SIZE 

100 INPUT "Format ted with CRC or ECC: "{ECCMODE* 

110 ECCMODE*LEFT* ( USC ( ECCMODE* ) , 1 ) 

1£0 IF ECCMODE* <> "E" AND ECCMODE* <> "C" THEN 100 

130 IF ECCMOD£*="E" THEN CHECKBYTES=4 ELSE CHECKS YTES=£ 

140 IF SIZE>£56 THEN GAP3=30 ELSE GAP3=15 

150 SECTORS=INT (CAPACITY/ (SIZE+GAP3+CHECKBYTES+41) > 

160 PRINT "Formatted capacity is" ;SECTORS*SIZE; "bytes per track using 1 

170 PRINT SECTORS;" sectors per track." 

180 END 
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PROGRAMMERS QUICK REFERENCE 



fia-ia. IfiSiS Fils 



CS- 



I AS I 

+ -■ + 

X 





1 
1 
1 
1 



Al 



I 
-+- 



A0 I RE- 



I WE- 



I 
-+ 



1 












X 



1 
1 


1 
1 



X 


1 

1 

1 

1 



Deselected 
Data Register 
Error Register 
Sector Count 
Sector Number 
Cylinder Low 
Cylinder High 
Size/Drive/Head 
Status Register 



Deselected 
Data Register 
Write Precomp 
Sector Count 
Sector Number 
Cylinder Low 
Cylinder High 

Size/Drive/Head 
Command Register 



Bi-ii. Valid £2S!mand.s 



TYPE 


1 
1 


COMMAND 


1 
1 


7 


6 


5 


BITS 
A 3 


£ 


1 





I 


1 


Restore 


1 











1 


r3 


r£ 


rl 


r0 


I 


1 


Seek 


1 





1 


1 


1 


r3 


rS 


rl 


r0 


II 


1 


Read Sector 


1 








1 





D 


M 


L 





III 


1 


Write Sector 


\l 








1, 


1 





M 


L 





III 


1 


Format Track 1 





. i 





1 















L=Long Read/Write 
M^Multiple Sector 



D=DMA Read Interrupt 
rX=Stepping Rate 
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Qi.2a. SDH Reflisigc Escasst 

Bit 
Function 



» 


7 


1 


6 5 


1 


4 3 1 


e 1 


1 


1 
1 


E 


1 
1 


Sec 
Size 


1 
1 


Drive 1 
Select 1 


Head 
Select 


1 
1 



E=ECC Mode 



1 Bit 


Bit 


1 & 


5 


1 





1 


1 


1 1 


1 



Sector Size 



256 Bytes 
512 Bytes 
128 Bytes 



I 
I 
I 
I 
+- 



Bit 
4 






1 
1 



Bit 
3 




1 



1 



Drive Selected 



Drive Sel 
Drive Sel 
Drive Sel 
Drive Sel 



1 
£ 
3 
4 



+_. . — 



Bit 

2 



Bit 
1 



Bit 





Head Selected 








1 
1 

1 
1 

+ 




1 
1 


1 
1 




1 

1 

1 



Head 





Head 


1 


Head 


2 


Head 


3 


Head 


4 


Head 


5 


Head 


& 


Head 


7 



+ 



Djufta. Statug and S=rrgr Register Bits 



1 Bit 


Status Register 


1 


Error Register 


1 


1 7 


Busy 


1 


Bad Block Detect 




1 & 


Ready 


1 


Uncorrectable 




1 5 


Write Fault 


1 


CRC Error - ID Field 




1 4 


Seek Complete 


1 


ID Not Found 




1 3 


Data Request 


1 


_ 




1 2 


Corrected 


1 


Aborted Command 




I 1 


— 


1 


TR000 




1 


Error 


1 


DAM not found 
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Jumper Modifications on HDC-1001 



Jumper G : It is a 3 PIN Jumper area located on the top left 
corner oT U18. 

This Jumper area is designed to send a ready wait signal to 
extend the processor cycle. 

£ should be jumpered to 1 or 3 depending on how the master 
processor is designed to look at either xrdy or prdy. If 
you are using Advanced Digital's Super Quad or Super Six, 
you must Jumper 2 to 1. 

Jumper H: Jumper H is located on the left hand side of U18. 
Jumper 9_ will option between 9_ or 8 to vectorin jumper 
through 7. Selection on Jumper will depend on master config- 
uration. 

Jumper A, B, C, D: These jumpers are designed to select drives 
A, B, C, D # with the new 8X305 processor on board^ It is not 
required to jumper these PINS, because the 8X305 will generate 
Drive Select inside automatically. 

SWl (Positioning) 

The SWl on the Hard Disk Controller is to determine the port 
addressing. Advanced Digital software is set up to look at 
port E0 which is the Hard Disk Controller base address. 
(SQHDC.MAC) So the position of the switch must be: 

1 2 3 456 78 

on on on off off off off 1 
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E. OPERATING SYSTEMS 

1. CP/M on 8" or 5 1/4" version 

S. Turbo-Dos on 8" or 5 1/4 " version 
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F. D R ft W I N 6 8 



EjlIu iQbiMBIie 
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MNEMONIC 



DESCRIPTION 
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S5Z 

CLKS 

ecci? 
cs 
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DIRECTION IN 

DHOLD 

DLYOAT 

PRO. 

DRQCL K 

ORSEL 

DRSI-DRS4 

DRUN 

HI FRO . 

CSAC 

HS0-HS2 

1A0- IA9 

IOB- IDIS 

INDEX 

INTCLK 

INTRO. 

1O0-IQT 

IVBB-J.VBT 

MCLK 

MFMW 

MR 

OSC 

RA0-RA9 

RCLK 

RTS 

RDAT 

RD , 4-RD6 1 RD2,RD0 

n 

READY 

fiTsTr 

RGATE 
RDVE 

Ewe 

SEER COMPLETE 

S.RCH 

STEP PULSE 

TIMCLK 

TRAC K 000 

WAEN 

VvTtfT 

WCLK 

Wl 

WGI 

WRITE FAULT 
WR0-WRT 

ibTa 

2XDR 
LIND EX 

wrTTI-PRoTeTT 



ADDRESS MARK DETECT 
TASK FILE ADDRESS SELECT, BITS 0-2 
BUS INPUT CONTROL 
BUS OUTPUT CONTROL 
CLOCK DATA 

ERROR CHECK/CORRECTION WORD INETIALIEE 
CARD SELECT 
DATA ACCESS LINES 
DIRECTION CONTROL 
DATA HOLD 
DELATED DATA 
DATA RECLUEST 
DATA REQ.UEST CLOCK 
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DATA RUN 
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READ DATA 
READ CONTROL LINES 
READ ENABLE 

REAOY STATUS FROM DRIVE 
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RAM OVERFLOW 
REDUCE WRITE CURRENT 
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SEARCH 

STEP PULSE TO ORWE 
TIME CLOCK SIGNAL FOR SAI000 
TRACK 00 STATUS FROM DRIVE 
WAIT ENABLE 
MEMORY NOT READY SIGNAL 
WRITE CLOCK 
WRITE ENABLE 
WRITE GATE INTERNAL .. 
WRITE FAULT STATUS FROM DRIVE 
• WRITE CONTROL LINES 
I- BYTE LOOK AHEAD 
2 X DATA REFERENCE CLOCK 
INTERNAL INDEX SYNC SIGNAL 
READ BYTE SYNC 
DMA SYSTEMS DRIVE STATUS SIGNAL 
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F. 1.1. MICROCONTROLLER 
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F. 1.2. BUS INTERFACE/DRIVE CONTROL 
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Chapter 1 
INTRODUCTION 



This manual provides the system designer with a com- 
plete technical discussion of the Signetics 8X305 Bipolar 
Microcontroller. The first two chapters address the func- 
tional operation of the 8X305, Chapter 3 is a reference for 
the device instruction set, Chapter 4 discusses timing 
considerations, and the final two chapters deal with ap- 
plication of the device. 

The 8X305 Data Sheet provides complementary data to 
this manual, including detailed timing and electrical char- 
acteristics. The 8X300 Family Product Capabilities 
Manual discusses the 8X305 in the context of the many 
compatible support devices available from Signetics. 
Together, the three documents provide the information 
necessary to design and implement a system that takes 
full advantage of the powerful features of the 8X305. 

The Signetics 8X305 Bipolar Microcontroller provides a 
real alternative to the complexity of bit-slice designs and 
the relatively slow speed of MOS microprocessors in high 
performance, cost effective control systems. 



1.1 DEVICE DESCRIPTION 

The 8X305 Microcontroller (Figure 1-1) is a monolithic 
Central Processing Unit implemented in bipolar Schottky 
technology. It is designed to operate at a speed of 200 
nsec for each 16-bit instruction, fetched on a dedicated 
bus for higher throughput. It controls a series of 
peripheral devices which are attached to it by means of a 
standard 8-bit bus known as the Interface Vector bus and 
its associated control signals. The 8X305 can be easily in- 
tegrated into most support systems using 8X300 Family 
support devices. 

The 8X305 is upward-compatible with its predecessor, the 
8X300, allowing enhancement of existing Microcontroller 
systems. Software written for the 8X300 will function cor- 
rectly on an 8X305. but the expansion of the instruction 
set and interna! working storage allows more flexible 
manipulation of data, higher throughput, and simplifica- 
tion of code. Care should be taken, however, in analyzing 
signal and timing requirements for each application 
where the Microcontroller is to be updated. 
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Figure 1-1. Architectural Overview of 8X305 Microcontroller 
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The 8X305 is designed to provide the optimum combina- 
tion of features for controller design: 

• Powerful, simple instruction set 

• Eight instruction classes 

• Single chip package 

• Bipolar speed 

• Family of compatible peripheral devices 

• Flexible bit manipulation in a single instruction 

• Single + 5 volt supply 

» TTL three-state bus operation 

1.2 DEVICE ARCHITECTURE 

An understanding of the internal architecture of the 
8X305 is required to maximize the efficiency of a design. 
Figure 1-1 illustrates the logical structure, but does not 
necessarily represent exact physical connections within 
the device. 



1.3 PIN DESCRIPTION 

The 8X305 Microcontroller is housed in a 0.9-inch wide, 
50-pin Dual In-Line (DIP) package, with pin assignments 
and designated functions as indicated in Figure 1-2. 



1.4 THE INTERFACE VECTOR BUS 

The 8X305 communicates with peripheral devices by 
means of a bidirectional, 8-bit TTL bus known as the Inter- 
face Vector, or IV bus. Five control signals generated by 
the 8X305 indicate the direction in which the bus is being 
driven and the configuration of the data or address on the 
bus. 

Devices connected to the IV bus are commonly referred 
to as I/O Ports. Any one of up to 256 such devices can be 
selected in a single cycle when the 8X305 places the I/O 
Port's unique address on the bus and asserts the Select 
Command (SC) signal. Once selected, an I/O Port normal- 
ly remains selected until the SC signal is again asserted 
with a different address on the bus. 



The instruction arrives at the Instruction Register from 
the Instruction Bus (Iq- hs). It is interpreted on the basis of 
the Op Code which defines the significance of the other 
bits in the instruction. Data paths within the chip are set 
up by the Decode and Control logic. External control 
signals are also generated by this logic. At a later point in 
the cycle, the Program Counter, Increment Logic, and Ad- 
dress Multiplexer generate the address of the next in- 
struction to be executed and place it in the Address 
Register. The address is then placed on the Instruction 
Address Bus (Ao-A 12 ) to fetch the next instruction. 

Ail timing is generated by an on-chip oscillator running at 
twice the actual instruction cycle speed. 

Source data can be accessed from three locations: 

• 16 internal registers 

• The IV bus 

• Absolute or modified constant specifications from the 
current instruction word 

Data from external sources can be manipulated by means 
of the Rotate and Mask Logic before becoming the first 
operand for an ALU operation. The implied second 
operand is the Auxiliary Register (AUX or R0). The result 
of the operation is stored in an Internal Register or 
transmitted to the IV bus. 

The sixteen 8-bit registers contained in the 8X305 are 
used as temporary storage of data and pointers. Three of 
these registers have special applications for IV bus ad- 
dress transmission and flag storage, leaving thirteen 
available as general-purpose storage. 



The direction of data flow is indicated by the Write Com- 
mand (WC) signal. This signal is asserted when data is be- 
ing placed on the bus by the 8X305, and is not asserted 
when data is being read from the bus. The data will nor- 
mally be read from or written into whatever I/O Port was 
last selected. 

To optimize the 8X305's capabilities in data manipulation 
and device selection, two control signals known as Left 
Bank (LB) and Right Bank (RB) are provided. These 
signals are asserted concurrently with other control 
signals based on the contents of the instruction word. 
They can be used in conjunction with the other signals to 
determine which I/O Port will be enabled at any given 
time. They can be used in a variety of ways, but the two 
most significant are as follows: 

1*. The optimum performance of the Microcontroller can 
be achieved by connecting the input I/O Port to one 
bank and the output port to the other. The two ports 
can then be selected concurrently and data can pass 
between them in a single cycle, resulting in a transfer 
rate of five megabytes per second. 

2. Since the bank select signal (LB or RB) must be 
asserted for a port to be enabled, two ports may share 
the same address provided that they are connected to 
opposite banks. This expands the number of I/O Ports 
that can be addressed in a single cycle to 512. 

Timing on the bus is synchronized with the Master Clock 
(MCLK) signal. Together with the other control signals, it 
enables the I/O Ports to access the IV bus at the correct 
points in the Microcontroller's instruction cycle. 
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PIN NO. 


IDENTIFIER 


FUNCTION 


1 


VCR 


Regulated voltage input from series-pass transistor (2N5320 or equivalent). 


2-9, 45-49 


A -A 12 


Program Address Lines: These active-high outputs permit direct addressing of up to 8192 words of 
program storage; A 12 is least significant bit. 


10, 11 


X1.X2 


Timing generator connections for a capacitor, a series resonant crystal, or an external clock source 
with complementary outputs. 


12 


GND 


Ground. 


13-28 


I -'15 


Instruction Lines: These active-high input lines receive 16-bit instructions from program storage; l 15 
is least significant bit. 


29 


sc 


Select Command: When high (binary 1), an address is being output on pins IVO through IV7. 


30 


wc 


Write Command: When high (binary 1), data is being output on pins IVO through IV7. 


31 


LB 


Left Bank Control: When low (binary 0), devices connected to the Left Bank are accessed. (Note. 
Typically, the LB signal is tied to the ME input pin of IIO peripherals.) 


32 


RB 


Right Bank Control: When low (binary 0), devices connected to the Right Bank are accessed (Note. 
Typically, the RB signal is tied to the ME input pin of IIO peripherals.) 


33-36, 
38-41 


ivo-iw 


Interface Vector (Input/Output Bus) — these bidirectional active-low three-state lines communicate 
data and/or addresses to I/O devices and memory locations. A low voltage level equals a binary "1"; 
iV7 is Least Significant Bit. 


37 


Vcc 


+ 5V power supply. 


42 


MCLK 


Master Clock: This active-high output signal is used for clocking I/O devices and/or synchronization 
of external logic. 


43 


RESET 


When RESET input is low (binary 0), the 8X305 is initialized — sets Program Counter/Address 
Register to zero and inhibits MCLK. For the period of time RESET is low, the Left Bank/Right Bank 
(LB/RB) signals are forced high asynchronously. 


44 


HALT 


When HALT input is low (binary 0), internal operation of the 8X305 stops at the start of next instruc- 
tion; MCLK is not inhibited nor is any internal register affected; however, both the Left Bank/ Right 
Bank (LB/RB) signals are synchronously driven high during the first quarter of the instruction cycle 
time and remain high during the time HALT is low. 


50 


VR 


Internally-generated reference output voltage for external series-pass regulator transistor. 



Figure 1-2. 8X305 Pin Designations and Functions 
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The I/O Ports must be capable of performing the address 
select operation, determining the direction of the bus, 
analyzing the bank control signals, and presenting or 
receiving data. Signetics offers numerous circuits that 
perform these functions for specific applications. Refer 
to the 8X300 Family Product Capabilities Manual for in- 
formation on these devices. 



1.5 SYSTEM ENVIRONMENT 

A generalized system configuration consisting of pro- 
gram storage (ROM/PROM), workin g stora ge (RAM), I/O 
devices, and the IV bus interface (IV0-IV7) is shown in 
Figure 1-3. Except for the off-chip timing crystal, the 
regulator transisto r, and an y user -generated logic 
associated with the HALT and RESET lines, no external 
parts are required for implementation. The TTL- 
compatible bus, simple interface logic, and bit- 
manipulation features optimize the 8X305 Microcon- 
troller for almost any system where high-speed operation, 
flexibility, and minimum board space are required. 

The program storage can consist of any ROM or PROM 
with sufficient access speed. It can be configured to the 



size of program required by the application, up to a max- 
imum of 8,192 instruction words. 

An interrupt Control Coprocessor, the 8X310, is available. 
This device connects to the Instruction Bus and Instruc- 
tion Address Bus, providing a single-chip interrupt 
handler and an enhanced ability for subroutine process- 
ing. 

Ports on the IV bus must be tailored to the application. 
Some additional high-speed working storage may also be 
required. This is implemented by assigning contiguous 
memory locations in a small byte-wide RAM to a series of 
contiguous port addresses. It is good practice to pair 
peripherals which transfer a good deal of data between 
each other on opposite banks, which enables single- 
instruction processing and transfer of data. 

Since they have been designed specifically for the IV bus, 
the 8X300 Family of parts provide the simplest solution to 
most requirements encountered in an 8X305 system. The 
family includes an array of I/O Ports, working storage 
RAM, and single-chip solutions to problems such as flop- 
py disk control and computer bus interfacing. 
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1.0 INTRODUCTION 

1.1 GENERAL DESCRIPTION 

The Shugart Model 1000 series disk drive is a random access storage device with one or two non-removable 
8" disks as storage media. Each disk surface employs one movable head to service 256 data tracks. The 
two models of the SA1000 series are the 1002 and the 1004 with single-and double platters respectively. The 
SA1002 provides 5 megabytes accessed by 2 movable heads and the SA1004 provides 10 megabytes ac- 
cessed by 4 movable heads. 

Low cost and unit reliability are achieved through the use of a unique band actuator design. The inherent 
simplicity of mechanical construction and electronic controls allows maintenance free operation throughout 
the life of the drive. 

Mechanical and contamination protection for the head, actuator and disks are provided by an impact resis- 
tant plastic and aluminum enclosure. A self contained recirculating system supplies clean air through a 0.3 
micron filter. Another absolute filter allows pressure equalization with ambient air. 

The optional SA1200 Data Separator PCB or equivalent circuitry is necessary to provide MFM en- 
coding/decoding, write precompensation, a crystal write oscillator and address mark writing and detection. 
These functions are also provided by the optional SA1400 controller. 

The SA1000 fixed disk drive's interface is similar* to the Shugart 8" family of floppy disk drives. The SA1000 
is designed to fit into the same physical space as the 8" floppies. 

Key Features: 

• Storage Capacity of 5.33 or 10.67megabyt.es. 

• Winchester design reliability. 

• Same physical size and identical mounting configuration as the SA800/850 floppies. 

• Uses the same D.C. voltages as the SA800/850 floppies. 

• Proprietary Fas Flex III band actuator. 

• 4.34 Mbits/second transfer rate. 

• Simple floppy like interface. 

•Existing floppy controllers are not compatible with the SA1000 due to differences in the data transfer rates. 
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1.2 Specification Summary 
1.2.1 Physical Specifications 

Environmental Limits 

Ambient Temperature = 
Relative Humidity = 
Maximum Wet Bulb = 

AC Power Requirements 
50/60 Hz ± 0.5Hz 
100/115 VAC Installations 
200/230 VAC Installations 

DC Voltage Requirements 



50°to115 F(10°to46 C) 

8% to 80% 

78° non-condensing 



= 90-1 27V at 1.1 A typical 
= 180-253V at 0.6A typical 



DC Voltage 


Ripple 
MVP-P 






+ 5 ± V 


50 


Stepping 
Steady State 


2.0 amp typical 

2.5 amp max. 

3.6 amp typical 

4.1 amp max. 


- 5 ± 0.5 V 50 
(-7 to -16V optional) (N/A) 




0.20 amp typical 
0.25 amp max. 


± 24 ± 3.6 V 


1000 


Stepping 
Steady State 


2.8 amp typical 
3.3 amp max. 
0.20 amp typical 
0.25 amp max. 


Mechanical Dimensions 






Height = 
Width = 
Depth = 
Weight = 


Rack Mount 

4.62 in. (117.3mm) 

8.55 in. (217.2mm) 

14.25 in. (362.0mm) 

17 lbs. (7.7Kg) 


Standard Mount 

4.62 in. (117.3mm) 

9.50 in. (241.3mm) 

14.25 in. (362.0mm) 

17 lbs. (7.7Kg) 





Heat Dissipation = 511 BTU/Hr. typical (150 Watts) 

1.2.2 Reliability Specifications 

MTBF: 8,000 POH typical usage 
PM: None Required 
MTTR: 30 minutes 
Component Life: 5 years 



Error Rates: 

Soft Read Errors: 
Hard Read Errors: 
Seek Errors: 



,10 



1 per 10 u bits read 



02 



1 per 10 bits read 
1 per 10 6 seeks 
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1.2.3 Performance Specifications 

Capacity SA1002 

Unformatted 

Per Drive 

Pet Surface 

Per Track 
Formatted 

Per Drive 

Per Surface 

Per Track 

Per Sector 

Sectors/Track 
Transfer Rate 
Access Time 

Track to Track 

Average 

Maximum 
Average Latency 

1.2.4 Functional Specifications 

Rotational Speed 
Recording Density 
Flux Density 
Track Density 
Cylinders 
Tracks 
R/W Heads 
Disks 



SA1004 



5.33 Mbytes 
2.67 Mbytes 
10.4 Kbytes 


10.67 Mbytes 
2.67 Mbytes 
10.4 Kbytes 


4.2 Mbytes 

2.1 Mbytes 

8.2 Kbytes 
256 bytes 

32 
1.34 Mbits/sec 


8.4 Mbytes 

2.1 Mbytes 

8.2 Kbytes 
256 bytes 

32 
4.34 Mbits/sec 


19 msec 
70 msec 
1 50 msec 
9.6 msec 


1 9 msec 
70 msec 
1 50 msec 
9.6 msec 


3125 rpm 

6270 bpi 

6270 fci 

172 tpi 

256 

512 

2 

1 


3125 rpm 

6270 bpi 

6270 fci 

172 tpi 

256 

1024 

4 

2 
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PRODUCT SPECIFICATION 



Q2000 FIXED DISK DRIVE 



The Q2000 fixed disk drive interface j similar to the 
Shugart 8" floppy drive and a superset of Shugart's 
SA1000 series disk drive in interface The Q2000 series 
disk drive is designed with the same form factor and 
power supply voltage requirements as 8" floppy drives. 



Key Feature s : 

° Storage Capacity of 10, 20, 30, or 40 megabytes 



° Winchester design reliability 



° Same physical size and mounting as 8" floppy drives 



° Uses the same D.C. voltages as 8" floppy. 



° Proprietary, rotary, high resolution, quiet head 
position actuator 

° 4 . 3 4 M bits/second transfer rate 

° Microprocessor controlled temperature compensation 
servo 
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PRODUCT SPFTTFTrATTHM 



Q2000 FIXED DISK DRIVE 



1.2 SPECIFICATION SUMMARY 

1.2.1 PHYSICAL SPECIFICATIONS 
ENVIRONMENTAL LIMITS 

NON OPERATIONAL 

Storage temperature 50°? to 150°F (10°C to 
65.5°C) 

Shipping temperature -40°F to 150°? ;-40°C to 
65.5°C) 

Storage and shipping altitude = 1000 to 40,000 fee: 

OPERATING 

Max Operating Altitude = 10,000 feet 

Ambient temperature = 50° to 115°F (10° to 46°C) 

Relacive humidity = 8% to 80% 

Maximum wet bulb = 78° non-condensing 
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I PRODUCT SPECIFICATION 



Q2000 FIXED DISK DRIVE 



AC POWER REQUIREMENTS 

50/60Hz+0.5Hz 

100/115VAC Installations = 90-127V at 1.0A Typical 
200/230VAC Installations = 180-253V at 0.5A Typical 
DC VOLTAGE REQUIREMENTS 

+24VDC+10* 1.25A Typical (1.5 A max) 

+ 5\?DC+5% 1.0A Typical (1.5 A max) 

-5VDC+5% (-7 to -16VDC optional) 0.2A Typical (0.25 A 
max ) 

MECHANICAL DIMENSIONS 

Height =4.50 in. (114.3mm) 
Width = 8.55 in. (217.2mm) 
Depth = 14.25 in. (362.0mm) 
Weigiit = 17 lbs. (7.7;< ( j) 
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PRODUCT SPECIFICATION 



Q2000 FIXED DISK DRIVE 



VIBRATION 



The level specified for vlbrvlon applies to three mutually 
perpendicular directions. ,'PrLnclple cabinet axes). Equipment 
shall be operable during and after the 



ia the following tabic 



le maximum vibration levels 



Operating 



Non-Operat ing 



FREQUENCY 

5-25 
25 - 55 
55 - 300 

5-25 
25-55 
55 - 300 



PEAK TO PEAK 
AMPLITUDE 



In 

.0014 

.0007 

.008 
.004 



G' s 



0.3 



2.0 



TRACK GEOMETRY 

Track width = .00225 + - .00015 inches 
Track spacing = .00287 inches average 
Track zero radius = 3.637 inches nominal. 
Track 511 radius = 2.155 inches nominal 
Shipping and landing zone track = 2.050 inches 
nomina i 
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| PRCDUCT SPECIFICATION | 

Q2000 FIXED DISK DRIVE 



HEAT DISSIPATION 

239 BTU/HR. TYP (70 Watts) Nominal 

1.2.2 RELIABILITY SPECIFICATION 

MTBF:8,000 POH typical usage 
PM:not required 
MTTR:30 minutes 
Component Life: 5 years 

ERROR RATES 

Soft read errors: 1 per 10 10 bits read 
Hard read errors: 1 per 10 12 bits read 
Seek, errors: 1 per 10 6 seeks 

These error rates assume that the drive is being operated 
within its specified limits. Errors caused by media 
defects are excluded. 

1.2.3 PERFORMANCE SPECIFICATIONS 

Q2010 Q2020 Q2030 Q2 04 
Capacity 
Unformatted 

Per drive 10.66Mb 21.33Mb 32.00Mb 42.66Mb 

Per surface 5.33Mb 5.33Mb 5.33Mb 5.33Mb 

Per track 10.40Kb 10.40Kb 10.40Kb 10.40Kb 
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PRODUCT SPECIFICATION 



Q2000 FIXED DISK DRIVE 



?ormatteu ' ;i j" : i ) 
P-ir drive 
Per surface 
Per track 
Per sector 
Sec tors/TK 
Transfer Rate 



8. 40Mb 

4.2 0Mb 

8. 2 0Kb 

25 6 Byte 

32 



16.80Mb 
4.2 0Mb 
8. 20Kb 



> j.20Mb 
4. 20." 
8.2 0Kb 



3 3.60Mb 
'+. 2 0Mb 
3.20Kb 



256 Bytes 256 Bytes 256 Bytes 
32 32 32 

4.3 4Mbits/ 4 . 34Mb i t s/ 4.34Mbits/ 4.34Mbits 
sec sec sec sec 



Access Time (Nominal voltages, 2 5°C 



TK to TK(max) 15 ms 

Average^max) 55 ms 

Full StrokeCtyp) 115 ms 
Avg. Latency 10 as 



15 ms 
60 ms 
115 ms 
10 ms 



1 5 ms 
60 ms 
115 ms 

10 ns 



15 ms 

65 ms 

115 ms 

10 ns 



1.2.4 FUNCTIONAL SPECIFICATIONS 



Worn Rotati 


onal 


Speed 


3000 


RPM 


3000 


RPM 


3 000 


RPM 


3000 


RP'I 


Max Rotational 


Speed 


3083 


RPM 


3083 


RPM 


3083 


RPM 


3083 


RPM 


Min Rotational 


S pe ed 


2 904 


RPM 


2904 


RPM 


2904 


RPi-I 


2904 


RPM 


Recording 


Dens 


ity 


6600 


bpi 


6600 


bp i 


6600 


Sp i 


6600 


bp i 


/lux Densi 


ty 




6600 


f ci 


6600 


f ci 


6600 


f ci 


6600 


f c i 


Track. Dens 


ity 




345 


tpi 


345 


tpi 


345 


tpi 


345 


tpi 


Cy xi nd e rs 






512 




512 




512 




512 




Tracks 






1024 




2048 




3072 




4096 




R/U Heads 






2 




4 




6 




8 




Disks 






1 




2. 




3 




4 




InJax 






1 




1 




1 




1 





Quantum guarantees a track capacity of a minimum of 10102 
bytes when written using a timing of 1.84 

microseconds/byte. 
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2.0 FUNCTIONAL CHARACTERISTI C? 

2.1 GENERAL OPERATION 

The Series 2000 fixed disk drive consists of 
read/write and control electronics, read/write 
heads, head positioning mechanism, madia, air 
filtration, and disk, rotation system. (See ^ig 
1-A for functional block. diagram) These 
components perform the following functions: 



Spin the disk(s) and generate control 
signals 

Position the heads over the selected track, 
with appropriate corrections in position 
to compensate for thermal effects on track 
loca t ion 

Read and write data 

Provide a contamination free environment 
around the siedLa and heads 

Perform diagnostics on the head 
positioning and servo systems 



2.2 READ/WRITE AND' CONTROL ELECTRONICS 

The electronics for the drive are packaged on two printed 
circuit boards, the control ?CB and the Transducer PCB. 



80 - J 



QUflflTUm CORPORATION 
I PRODUCT SPECIFICATION 



Q2000 FIXED DISK DRIVE 



2.2.1 TRANSDUCER PCB 

The Transducer PCB contains the following circuits: 

Optical position encoder detector circuits 
Raw track detector circuit 
AGC circuit for position sensors 
Head select diode matrix 
Actuator motor connections 
Drive capacity option jumpers 
2.2.2 CONTROL PCB 

The main PCB contains the following circuits: 
Index detector circuit 

Head positioning actuator circuits 

Microprocessor (with ROM Program*) for 
diagnostics and head positioning control 

Read/write ampli f is r /dr 1 ve rs 

Head select circuits 

Drive select circuit 

Drive ready circuit 

Write fault .detection circuit 

Power on reset circuit 

Track. detection circuit 

2. 3 DRIVE MECHANISM 

The spindle rotates at 3000 rpm through a belt drive 
from an AC motor. Either 50 or 60Hz power is 
accomodated by changing the .notor drive pulley and 
belc 220/230VAC operation can be utilized by a 
.aotor change. [See Appendix C) 
* ©Quantum Corp. 1981 
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Q2000 FIXED DISK DRIVE 
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2-4 READ/WRITE HEAD AND DISKS 

The recording media is a lubricated thin magnetic oxide 
coated on an 8 inch C 200mm) ' diameter aluminum substrat 
This lubricated coating formulation, together with th 
low load force/low mass Winchester type flying head 
permit reliable contact start/stop operation. To protect 
recorded data, heads are positioned in a landing zone 
inside of cylinder 511 when the disks are not up to speed. 

2-5 HEAD POSITIONING SYSTEM 

The head positioning system consists of three major 
elements: rotary torque motor actuator, optical track 
position encoder, and temperature compensation servo. 

2.5.1 ROTARY TORQUE MOTOR ACTUATOR :?IG. 3) 

The read/write heads are counted on counterbalanced arms 
attached to the hub of the rotary torque motor. This 
configuration applies a pure torque to the rotor. The 
balanced system maximizes bearing life and leads "to high 
mechanical stability and maximum vibration resistance. 

The motor is of simple construction consisting of a ring 
magnet, two flat plate pole pieces, a single plane moving 
coil and two bearings. This system is faster than 
stepper motors and its performance matches many voice 
coil actuator systems. 
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I PRODUCT SPECIFICATION | 



Q2000 FIXED DISK DRIVE 



2.5.2 OPTICAL TRACK POSITION ENCODER 

The optical track position encoder is a proven technology 
utilizing a highly reliable photo etched scale, an LED 
light source and photodiode sensors. The encoder 
components are located inside the bubble with the scale 
attached to the lowermost actuator arm. 



2.5.3 TEMPERATURE COMPENSATION SERVO 

The temperature compensation (fine) servo obtains 
position feedback directly from the disk surface once per 
revolution. This track location coding is embedded 
between the last inter-record gap and the index pulse. 
Writing is inhibited by the drive during this time but 
reading is not. The IF or 2F servo signal will appear on 
the MFM read data lines. Compatibility is raaincained 
with like drives by reducing the disk rotational speed by 
4%. This servo method places no restricions on format 
and allows the same data rate and track capacity as other 
comparabLe competitive units. 
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